jQuery基础自查手册
本文最后更新于:2020年12月24日 下午
1.概述
jQuery即Java和Query,是辅助JavaScript开发的js类库
- 使用jQuery必须先引入jQuery库:
<script type="text/javascript" src="../script/jquery-1.7.2.js"></script>
- 示例:为按钮添加响应函数
- 先使用jQuery查询到标签对象
- 再使用
标签对象.click(function(){});
进行绑定
2.jQuery的核心函数
$
是 jQuery 的核心函数,能完成 jQuery 的很多功能。$()
就是调用$这个函数
- 传入参数为函数 :在文档加载完成后执行这个函数。相当于
window.onload = function(){}
- 传入参数为HTML 字符串:根据这个字符串创建元素节点对象
- 传入参数为选择器字符串:
$(“#id 属性值”);
id 选择器,根据 id 查询标签对象$(“标签名”);
标签名选择器,根据指定的标签名查询标签对象$(“.class 属性值”);
类型选择器,可以根据 class 属性查询标签对象
- 传入参数为 DOM 对象 时:将DOM对象包装为jQuery对象返回
3.jQuery对象和DOM对象
(1)概念
Dom对象 | jQuery对象 |
---|---|
1.通过 getElementById()查询出来的标签对象是 Dom 对象 2.通过 getElementsByName()查询出来的标签对象是 Dom 对象 3.通过 getElementsByTagName()查询出来的标签对象是 Dom 对象 4.通过 createElement() 方法创建的对象,是 Dom 对象 |
5.通过 JQuery 提供的 API 创建的对象,是 JQuery 对象 6.通过 JQuery 包装的 Dom 对象,也是 JQuery 对象 7.通过 JQuery 提供的 API 查询到的对象,是 JQuery 对象 |
DOM 对象 Alert 出来的效果是:[object HTML 标签名 Element] | jQuery 对象 Alert 出来的效果是:[object Object] |
(2)jQuery对象的本质
jQuery 对象是 dom 对象的数组 + jQuery 提供的一系列功能函数。
(3)对象使用区别
- jQuery 对象不能使用 DOM 对象的属性和方法,如innerHTML
- DOM 对象也不能使用 jQuery 对象的属性和方法,如click.function(){}
(4)对象互转
- Dom对象转换为jQuery对象:
var $obj = $(Dom 对象)
- jQuery对象转换为Dom对象:
var dom = jQuery对象[下标]
4.jQuery选择器
(1)基本选择器
#id
:根据给定的ID匹配一个元素。如$("#myDiv");
element
:根据给定的元素名匹配所有元素。如$("div");
.class
:根据给定的类匹配元素。如$(".myClass");
*
:返回所有元素selector1,selector2 组合选择器
:将每一个选择器匹配到的元素合并后一起返回。$("div,span,p.myClass")
p.myClass表示标签名必须是 p 标签,而且 class 类型还要是 myClass
(2)层级选择器
ancestor descendant
后代选择器 :在给定的祖先元素下匹配所有的后代元素。如$("form input")
可用来找到表单中所有的 input 元素。parent > child
子元素选择器:在给定的父元素下匹配所有的子元素。如$("form > input")
可用来匹配表单中所有的子级input元素prev + next
相邻元素选择器:匹配所有紧接在 prev 元素后的 next 元素prev ~ sibings
之后的兄弟元素选择器:匹配 prev 元素之后的所有 siblings 元素
<form>
<label>Name:</label>
<input name="name" />
<fieldset>
<label>Newsletter:</label>
<input name="newsletter" />
</fieldset>
</form>
<input name="none" />
$("form input") // [<input> name ="name"/>, <input name="newsletter" />]
$("form > input") // [ <input name="name" /> ]
$("label + input") // [<input name="name" />, <input name="newsletter" />]
$("form ~ input") // [<input name="none" />]
(3)过滤选择器
🏄♂️ 基本过滤器
:first
:获取第一个元素,如$('li:first');
:last
:获取最后个元素:not(selector)
:去除所有与给定选择器匹配的元素,如$("input:not(:checked)")
:even
:匹配所有索引值为偶数的元素,从 0 开始计数,如$("tr:even")
:odd
:匹配所有索引值为奇数的元素,从 0 开始计数:eq(index)
: 匹配一个给定索引值的元素,如$("tr:eq(1)")
(索引从0开始):gt(index)
:匹配所有大于给定索引值的元素:lt(index)
:匹配所有小于给定索引值的元素:header
:匹配如 h1, h2, h3 之类的标题元素,如$(":header").css("background", "#EEE");
:animated
:匹配所有正在执行动画效果的元素,如$("div:not(:animated)")
.
🏄♂️ 内容过滤器
:contains(text)
:匹配包含给定文本的元素,如$("div:contains('John')")
:empty
:匹配所有不包含子元素或者文本的空元素,如$("td:empty")
:parent
:匹配含有子元素或者文本的元素,如$("td:parent")
:has(selector)
:匹配含有选择器所匹配的元素的元素,如$("div:has(p)").addClass("test");
会给所有包含 p 元素的 div 元素添加一个 text 类
🏄♂️ 属性过滤器
[attribute]
匹配包含给定属性的元素。如$("div[id]")
查找所有含有 id 属性的 div 元素[attribute=value]
匹配给定的属性是某个特定值的元素。如$("input[name='newsletter']").
[attribute!=value]
匹配所有不含有指定的属性,或者属性不等于特定值的元素。如$("input[name!='newsletter']").
[attribute^=value]
匹配给定的属性是以某些值开始的元素[attribute$=value]
匹配给定的属性是以某些值结尾的元素[attribute*=value]
匹配给定的属性是以包含某些值的元素[attrSel1][attrSel2][attrSelN]
复合属性选择器,需要同时满足多个条件时使用,如$("input[id][name$='man']")
🏄♂️ 表单过滤器
:input
:匹配所有 input, textarea, select 和 button 元素:text
:匹配所有文本输入框:password
:匹配所有的密码输入框:radio
:匹配所有的单选框:checkbox
:匹配所有的复选框:submit
:匹配所有提交按钮:image
:匹配所有 img 标签:reset
:匹配所有重置按钮:button
:匹配所有input type=button <button>
按钮:file
:匹配所有 input type=file 文件上传:hidden
:匹配所有不可见元素 display:none 或 input type=hidden
🏄♂️ 表单过滤器
:enabled
:匹配所有可用元素,如$("input:enabled")
:disabled
:匹配所有不可用元素,如$("input:disabled")
:checked
: 匹配所有选中的被选中元素(复选框、单选框等,不包括select中的option):selected
: 匹配所有选中的option元素,如$("select option:selected")
(4)练习题
- 全选全不选
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
<script type="text/javascript" src="../../script/jquery-1.7.2.js"></script>
<script type="text/javascript">
$(function(){
// 给全选绑定单击事件
$("#checkedAllBtn").click(function () {
$(":checkbox").prop("checked",true); // 所有的复选框的checked属性设置为true
});
// 给全不选绑定单击事件
$("#checkedNoBtn").click(function () {
$(":checkbox").prop("checked",false); // 所有的复选框的checked属性设置为true
});
// 反选单击事件
$("#checkedRevBtn").click(function () {
// 查询全部的球类的复选框
$(":checkbox[name='items']").each(function () {
// 在each遍历的function函数中,有一个this对象。这个this对象是当前正在遍历到的dom对象
this.checked = !this.checked;
});
// 要检查 是否满选
// 获取全部的球类个数
var allCount = $(":checkbox[name='items']").length;
// 再获取选中的球类个数
var checkedCount = $(":checkbox[name='items']:checked").length;
// if (allCount == checkedCount) {
// $("#checkedAllBox").prop("checked",true);
// } else {
// $("#checkedAllBox").prop("checked",false);
// }
$("#checkedAllBox").prop("checked",allCount == checkedCount);
});
// 【提交】按钮单击事件
$("#sendBtn").click(function () {
// 获取选中的球类的复选框
$(":checkbox[name='items']:checked").each(function () {
alert(this.value);
});
});
// 给【全选/全不选】绑定单击事件
$("#checkedAllBox").click(function () {
// 在事件的function函数中,有一个this对象,这个this对象是当前正在响应事件的dom对象
// alert(this.checked); // this.checked表示该复选框的选中状态
$(":checkbox[name='items']").prop("checked",this.checked);
});
// 给全部球类绑定单击事件,当前满时自动显示全选
$(":checkbox[name='items']").click(function () {
// 要检查 是否满选
// 获取全部的球类个数
var allCount = $(":checkbox[name='items']").length;
// 再获取选中的球类个数
var checkedCount = $(":checkbox[name='items']:checked").length;
$("#checkedAllBox").prop("checked",allCount == checkedCount);
});
});
</script>
</head>
<body>
<form method="post" action="">
你爱好的运动是?<input type="checkbox" id="checkedAllBox" />全选/全不选
<br />
<input type="checkbox" name="items" value="足球" />足球
<input type="checkbox" name="items" value="篮球" />篮球
<input type="checkbox" name="items" value="羽毛球" />羽毛球
<input type="checkbox" name="items" value="乒乓球" />乒乓球
<br />
<input type="button" id="checkedAllBtn" value="全 选" />
<input type="button" id="checkedNoBtn" value="全不选" />
<input type="button" id="checkedRevBtn" value="反 选" />
<input type="button" id="sendBtn" value="提 交" />
</form>
</body>
</html>
5.jQuery元素筛选
eq(index)
:获取给定索引的元素,功能跟 :eq() 一样first()
:获取第一个元素,功能跟 :first 一样last()
:获取最后一个元素,功能跟 :last 一样filter(exp)
: 留下匹配的元素is(exp)
:判断是否匹配给定的选择器,只要有一个匹配就返回,truehas(exp)
:返回包含有匹配选择器的元素的元素,功能跟 :has 一样not(exp)
:删除匹配选择器的元素,功能跟 :not 一样children(exp)
: 返回匹配给定选择器的子元素,功能跟 parent>child 一样find(exp)
:返回匹配给定选择器的后代元素,功能跟 ancestor descendant 一样next()
:返回当前元素的下一个兄弟元素,功能跟 prev + next 功能一样nextAll()
:返回当前元素后面所有的兄弟元素,功能跟 prev ~ siblings 功能一样nextUntil()
:返回当前元素到指定匹配的元素为止的后面元素parent()
:返回父元素prev(exp)
:返回当前元素的上一个兄弟元素prevAll()
:返回当前元素前面所有的兄弟元素prevUnit(exp)
: 返回当前元素到指定匹配的元素为止的前面元素siblings(exp)
:返回所有兄弟元素add()
:把 add 匹配的选择器的元素添加到当前 jquery 对象中,如$("p").add(document.getElementById("a"))
6.jQuery属性操作
html()
- 可以设置和获取起始标签和结束标签中的内容,跟dom 属性innerHTML 一样。
text()
- 它可以设置和获取起始标签和结束标签中的文本,跟dom 属性innerText 一样。
val()
:它可以设置和获取表单项的value 属性值,跟dom 属性value 一样
val方法可以同时设置多个表单项的选中状态,如
$("#multiple,#single,:radio,:checkbox").val(["radio2","checkbox1","checkbox3","mul1","mul4","sin3"] );
<!DOCTYPE html>
<html lang="zh_CN">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script type="text/javascript" src="script/jquery-1.7.2.js"></script>
<script type="text/javascript">
$(function () {
// 不传参数,是获取,传递参数是设置
alert( $("div").html() );// 获取
$("div").html("<h1>我是div中的标题 1</h1>");// 设置
// 不传参数,是获取,传递参数是设置
alert( $("div").text() ); // 获取文本(会去掉标签信息,如<span>这种)
$("div").text("<h1>我是div中的标题 1</h1>"); // 设置
// // 不传参数,是获取,传递参数是设置
$("button").click(function () {
alert($("#username").val());//获取
$("#username").val("超级程序猿");// 获取之后再设置(上一步未运行,不会运行这一步)
});
});
</script>
</head>
<body>
<div>我是div标签 <span>我是div中的span</span></div>
<input type="text" name="username" id="username" />
<button>操作输入框</button>
</body>
</html>
attr()/prop()
两者均可以设置和获取属性的值,
不推荐
attr()
操作checked、readOnly、selected、disabled 等等。(没选中返回undefined,选中返回checked)- 只推荐
prop()
操作checked、readOnly、selected、disabled 等等。(没选中返回false,选中了返回true) - attr 方法还可以操作非标准的属性。比如自定义属性:abc,bbj
$(function () {
//attr
alert( $(":checkbox:first").attr("name") ); // 获取
$(":checkbox:first").attr("name","abc") ; // 设置
// 官方觉得返回undefined是一个错误,因此更推荐采用prop
$(":checkbox").prop("checked",false ); // 设置checked属性为false
// 操作自定义属性
$(":checkbox:first").attr("abc","abcValue");
alert( $(":checkbox:first").attr("abc") );
});
7.DOM的增删改
(1)内部插入
appendTo()
:比如a.appendTo(b),即把a插入到b子元素末尾,成为最后一个子元素prependTo()
:比如a.prependTo(b),即把a插到b所有子元素前面,成为第一个子元素
(2)外部插入:
insertAfter()
:比如a.insertAfter(b) 得到bainsertBefore()
:比如a.insertBefore(b) 得到ab
(3)替换:
replaceWith()
:比如a.replaceWith(b) 用b替换掉areplaceAll()
:比如a.replaceAll(b) 用a替换掉所有b
(4)删除:
remove()
:比如a.remove(); 删除a 标签empty()
:比如a.empty(); 清空a 标签里的内容
$("<h1>标题</h1>").prependTo( $("div") );
$("<h1>标题</h1>").insertAfter("div");
$("<h1>标题</h1>").insertBefore( $("div") );
$("<h1>标题</h1>").replaceWith("div");
$("div").replaceWith( $("<h1>标题</h1>") );
$("<h1>标题</h1>").replaceAll( "div" );
$("div").remove();
$("div").empty();
(5)练习题
- 从左到右、从右到左的添加与删除
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
<style type="text/css">
select {
width: 100px;
height: 140px;
}
div {
width: 130px;
float: left;
text-align: center;
}
</style>
<script type="text/javascript" src="script/jquery-1.7.2.js"></script>
<script type="text/javascript">
// 页面加载完成
$(function () {
// 第一个按钮 【选中添加到右边】
$("button:eq(0)").click(function () {
$("select:eq(0) option:selected").appendTo($("select:eq(1)"));
});
// 第二个按钮 【全部添加到右边】
$("button:eq(1)").click(function () {
$("select:eq(0) option").appendTo($("select:eq(1)"));
});
// 第三个按钮 【选中删除到左边】
$("button:eq(2)").click(function () {
$("select:eq(1) option:selected").appendTo($("select:eq(0)"));
});
// 第四个按钮 【全部删除到左边】
$("button:eq(3)").click(function () {
$("select:eq(1) option").appendTo($("select:eq(0)"));
});
});
</script>
</head>
<body>
<div id="left">
<select multiple="multiple" name="sel01">
<option value="opt01">选项1</option>
<option value="opt02">选项2</option>
<option value="opt03">选项3</option>
<option value="opt04">选项4</option>
<option value="opt05">选项5</option>
<option value="opt06">选项6</option>
<option value="opt07">选项7</option>
<option value="opt08">选项8</option>
</select>
<button>选中添加到右边</button>
<button>全部添加到右边</button>
</div>
<div id="rigth">
<select multiple="multiple" name="sel02">
</select>
<button>选中删除到左边</button>
<button>全部删除到左边</button>
</div>
</body>
</html>
- 自定义添加与删除
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Untitled Document</title>
<link rel="stylesheet" type="text/css" href="styleB/css.css" />
<script type="text/javascript" src="../../script/jquery-1.7.2.js"></script>
<script type="text/javascript">
$(function () {
// 创建一个用于复用的删除的function函数
var deleteFun = function(){
// alert("删除 操作 的function : " + this);
// 在事件响应的function函数中,有一个this对象。这个this对象是当前正在响应事件的dom对象。
var $trObj = $(this).parent().parent();
var name = $trObj.find("td:first").text();
/**
* confirm 是JavaScript语言提供的一个确认提示框函数。你给它传什么,它就提示什么<br/>
* 当用户点击了确定,就返回true。当用户点击了取消,就返回false
*/
if( confirm("你确定要删除[" + name + "]吗?") ){
$trObj.remove();
}
// return false; 可以阻止 元素的默认行为。
return false;
};
// 给【Submit】按钮绑定单击事件
$("#addEmpButton").click(function () {
// 获取输入框,姓名,邮箱,工资的内容
var name = $("#empName").val();
var email = $("#email").val();
var salary = $("#salary").val();
// 创建一个行标签对象,添加到显示数据的表格中
var $trObj = $("<tr>" +
"<td>" + name + "</td>" +
"<td>" + email + "</td>" +
"<td>" + salary + "</td>" +
"<td><a href=\"deleteEmp?id=002\">Delete</a></td>" +
"</tr>");
// 添加到显示数据的表格中
$trObj.appendTo( $("#employeeTable") );
// 给添加的行的a标签绑上事件
$trObj.find("a").click( deleteFun ); // deleteFun()表示调用,单纯的deleteFun表示函数
});
// 给删除的a标签绑定单击事件
$("a").click( deleteFun );
});
</script>
</head>
<body>
<table id="employeeTable">
<tr>
<th>Name</th>
<th>Email</th>
<th>Salary</th>
<th> </th>
</tr>
<tr>
<td>Tom</td>
<td>tom@tom.com</td>
<td>5000</td>
<td><a href="deleteEmp?id=001">Delete</a></td>
</tr>
<tr>
<td>Jerry</td>
<td>jerry@sohu.com</td>
<td>8000</td>
<td><a href="deleteEmp?id=002">Delete</a></td>
</tr>
<tr>
<td>Bob</td>
<td>bob@tom.com</td>
<td>10000</td>
<td><a href="deleteEmp?id=003">Delete</a></td>
</tr>
</table>
<div id="formDiv">
<h4>添加新员工</h4>
<table>
<tr>
<td class="word">name: </td>
<td class="inp">
<input type="text" name="empName" id="empName" />
</td>
</tr>
<tr>
<td class="word">email: </td>
<td class="inp">
<input type="text" name="email" id="email" />
</td>
</tr>
<tr>
<td class="word">salary: </td>
<td class="inp">
<input type="text" name="salary" id="salary" />
</td>
</tr>
<tr>
<td colspan="2" align="center">
<button id="addEmpButton" value="abc">
Submit
</button>
</td>
</tr>
</table>
</div>
</body>
</html>
8.CSS样式操作
addClass()
添加样式removeClass()
删除样式toggleClass()
有就删除,没有就添加样式。offset()
获取和设置元素的坐标。
<script type="text/javascript">
$(function(){
var $divEle = $('div:first');
$('#btn01').click(function(){
//addClass() - 向被选元素添加一个或多个类
$divEle.addClass('redDiv blueBorder');
});
$('#btn02').click(function(){
//removeClass() - 从被选元素删除一个或多个类
$divEle.removeClass();
});
$('#btn03').click(function(){
//toggleClass() - 对被选元素进行添加/删除类的切换操作
$divEle.toggleClass('redDiv')
});
$('#btn04').click(function(){
//offset() - 返回第一个匹配元素相对于文档的位置。
var pos = $divEle.offset();
console.log(pos);
$divEle.offset({
top:100,
left:50
});
});
})
</script>
9.jQuery动画
(1)基本动画
show()
:将隐藏的元素显示hide()
:将可见的元素隐藏。toggle()
:可见就隐藏,不可见就显示。- 以上动画方法都可以添加参数:
- 第一个参数是动画执行的时长,以毫秒为单位
- 第二个参数是动画的回调函数(动画完成后自动调用的函数)
(2)淡入淡出动画
fadeIn()
:淡入(慢慢可见)fadeOut()
:淡出(慢慢消失)fadeTo()
:在指定时长内慢慢的将透明度修改到指定的值。0 透明,1 完成可见,0.5 半透明fadeToggle()
:淡入/淡出切换
<script type="text/javascript">
/*
基本
show([speed,[easing],[fn]])
hide([speed,[easing],[fn]])
toggle([speed],[easing],[fn])
滑动
slideDown([spe],[eas],[fn])
slideUp([speed,[easing],[fn]])
slideToggle([speed],[easing],[fn])
淡入淡出
fadeIn([speed],[eas],[fn])
fadeOut([speed],[eas],[fn])
fadeTo([[spe],opa,[eas],[fn]])
fadeToggle([speed,[eas],[fn]])
*/
$(function(){
//显示 show()
$("#btn1").click(function(){
$("#div1").show(2000,function () {
alert("show动画完成 ")
});
});
//隐藏 hide()
$("#btn2").click(function(){
$("#div1").hide(1000,function () {
alert("hide动画 执行完成 ")
});
});
//切换 toggle()
$("#btn3").click(function(){
$("#div1").toggle(1000,function () {
alert("toggle动画 完成 ")
});
});
// var abc = function(){
// $("#div1").toggle(1000,abc);
// }
// abc();
//淡入 fadeIn()
$("#btn4").click(function(){
$("#div1").fadeIn(2000,function () {
alert("fadeIn完成 ")
});
});
//淡出 fadeOut()
$("#btn5").click(function(){
$("#div1").fadeOut(2000,function () {
alert("fadeOut完成 ")
});
});
//淡化到 fadeTo()
$("#btn6").click(function(){
$("#div1").fadeTo(2000,0.5,function () {
alert('fadeTo完成 ')
});
});
//淡化切换 fadeToggle()
$("#btn7").click(function(){
$("#div1").fadeToggle(1000,function () {
alert("fadeToggle完成 ")
});
});
})
</script>
(3)练习
- 品牌展示:
- 1.点击按钮的时候,隐藏和显示卡西欧之后的品牌。
- 2.当显示全部内容的时候,按钮文本为“显示精简品牌”
然后,小三角形向上。所有品牌产品为默认颜色。 - 3.当只显示精简品牌的时候,要隐藏卡西欧之后的品牌,按钮文本为“显示全部品牌”
然后小三形向下。并且把佳能,尼康的品牌颜色改为红色(给li 标签添加promoted 样式即可)
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>品牌展示练习</title>
<style type="text/css">
* {
margin: 0;
padding: 0;
}
body {
font-size: 12px;
text-align: center;
}
a {
color: #04D;
text-decoration: none;
}
a:hover {
color: #F50;
text-decoration: underline;
}
.SubCategoryBox {
width: 600px;
margin: 0 auto;
text-align: center;
margin-top: 40px;
}
.SubCategoryBox ul {
list-style: none;
}
.SubCategoryBox ul li {
display: block;
float: left;
width: 200px;
line-height: 20px;
}
.showmore , .showless{
clear: both;
text-align: center;
padding-top: 10px;
}
.showmore a , .showless a{
display: block;
width: 120px;
margin: 0 auto;
line-height: 24px;
border: 1px solid #AAA;
}
.showmore a span {
padding-left: 15px;
background: url(img/down.gif) no-repeat 0 0;
}
.showless a span {
padding-left: 15px;
background: url(img/up.gif) no-repeat 0 0;
}
.promoted a {
color: #F50;
}
</style>
<script type="text/javascript" src="script/jquery-1.7.2.js"></script>
<script type="text/javascript">
$(function() {
// 基本初始状态
$("li:gt(5):not(:last)").hide();
// 给功能的按钮绑定单击事件
$("div div a").click(function () {
// 让某些品牌,显示,或隐藏
$("li:gt(5):not(:last)").toggle();
// 判断 品牌,当前是否可见
if( $("li:gt(5):not(:last)").is(":hidden") ){
// 品牌隐藏的状态 :1 显示全部品牌 == 角标向下 showmore
$("div div a span").text("显示全部品牌");
$("div div").removeClass();
$("div div").addClass("showmore");
// 去掉高亮
$("li:contains('索尼')").removeClass("promoted");
} else {
// 品牌可见的状态:2 显示精简品牌 == 角标向上 showless
$("div div a span").text("显示精简品牌");
$("div div").removeClass();
$("div div").addClass("showless");
// 加高亮
$("li:contains('索尼')").addClass("promoted");
}
return false;
});
});
</script>
</head>
<body>
<div class="SubCategoryBox">
<ul>
<li><a href="#">佳能</a><i>(30440) </i></li>
<li><a href="#">索尼</a><i>(27220) </i></li>
<li><a href="#">三星</a><i>(20808) </i></li>
<li><a href="#">尼康</a><i>(17821) </i></li>
<li><a href="#">松下</a><i>(12289) </i></li>
<li><a href="#">卡西欧</a><i>(8242) </i></li>
<li><a href="#">富士</a><i>(14894) </i></li>
<li><a href="#">柯达</a><i>(9520) </i></li>
<li><a href="#">宾得</a><i>(2195) </i></li>
<li><a href="#">理光</a><i>(4114) </i></li>
<li><a href="#">奥林巴斯</a><i>(12205) </i></li>
<li><a href="#">明基</a><i>(1466) </i></li>
<li><a href="#">爱国者</a><i>(3091) </i></li>
<li><a href="#">其它品牌相机</a><i>(7275) </i></li>
</ul>
<div class="showmore">
<a href="more.html"><span>显示全部品牌</span></a>
</div>
</div>
</body>
</html>
10.jQuery事件操作
(1)页面载入
jQuery函数$( function(){} ); |
原生JS函数window.onload = function(){} |
|
---|---|---|
触发时间 | 浏览器的内核解析完页面的标签创建好DOM对象后立即执行 | 除了要等浏览器内核解析完标签创建好DOM对象,还要等标签显示时需要的内容加载完成,再执行函数 |
触发顺序 | 先 | 后 |
触发次数 | 依次执行注册的全部的function | 只执行最后一个function |
(2)事件处理
click()
:它可以绑定单击事件(传function),以及触发单击事件(不传,单纯的.click)mouseover()
:鼠标移入事件mouseout()
:鼠标移出事件bind()
:可以给元素一次性绑定一个或多个事件,如$("h1").bind("click mouseover",function(){})
one()
:使用上跟bind一样。但是one方法绑定的事件只会响应一次。unbind()
:跟bind方法相反的操作,解除事件的绑定。不添加参数时,全部解绑。live()
:也是用来绑定事件。它可以用来绑定选择器匹配的所有元素的事件。哪怕这个元素是后面动态创建出来的也有效。
(3)事件的冒泡
事件的冒泡是指,父子元素同时监听同一个事件。当触发子元素的事件的时候,同一个事件也被传递到了父元素的事件里去响应。
- 那么如何阻止事件冒泡呢?
在子元素事件函数体内,return false
; 可以阻止事件的冒泡传递。
(4)事件对象
事件对象,是封装有触发的事件的信息的一个javascript 对象。
那么,如何获取javascript 事件对象呢?
- 在给元素绑定事件的时候,在事件的function( event ) 参数列表中添加一个参数
event
。这个event 就是javascript 传递参事件处理函数的事件对象。
// 1.原生javascript 获取事件对象
window.onload = function () {
document.getElementById("areaDiv").onclick = function (event) {
console.log(event);
}
}
// 2.jQuery 代码获取事件对象
$(function () {
$("#areaDiv").click(function (event) {
console.log(event);
});
});
// 3.使用bind 同时对多个事件绑定同一个函数。怎么获取当前操作是什么事件。
$("#areaDiv").bind("mouseover mouseout",function (event) {
if (event.type == "mouseover") {
console.log("鼠标移入");
} else if (event.type == "mouseout") {
console.log("鼠标移出");
}
});
(5)练习
- 图片的鼠标跟随
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
<style type="text/css">
body {
text-align: center;
}
#small {
margin-top: 150px;
}
#showBig {
position: absolute;
display: none;
}
</style>
<script type="text/javascript" src="script/jquery-1.7.2.js"></script>
<script type="text/javascript">
$(function(){
$("#small").bind("mouseover mouseout mousemove",function (event) {
if (event.type == "mouseover") {
$("#showBig").show();
} else if (event.type == "mousemove") {
console.log(event);
$("#showBig").offset({
left: event.pageX + 10,
top: event.pageY + 10
});
} else if (event.type == "mouseout") {
$("#showBig").hide();
}
});
});
</script>
</head>
<body>
<img id="small" src="img/small.jpg" />
<div id="showBig">
<img src="img/big.jpg">
</div>
</body>
</html>
本博客所有文章除特别声明外,均采用 CC BY-SA 4.0 协议 ,转载请注明出处!