JQuery
JQuery基础
一个JavaScript框架,简化JS开发
JavaScript框架:本质上就是一些js文件,封装了js的代码而已
自定义一个简单的JS框架
封装一个js文件(这个js文件就可以称之为一个JS框架)
1
2
3
4
5//封装方法,根据id来获取元素对象 get是定义的方法名,也可以使用$表示
function get(id){
var obj = document.getElementById(id);
return obj;
}在html页面中使用上述js文件
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>自定义JS框架</title>
<script src="js/js名称.js"></script>
</head>
<body>
<div id="div1">div1...</div>
<div id="div2">div2...</div>
</body>
<script>
//1.根据id获取元素对象
var div1 = get("div1");
var div2 = get("div2");
//2.获取标签体内容
alert(div1.innerHTML);
alert(div2.innerHTML);
</script>
</html>
快速入门
步骤:
- 下载JQuery
- 导入JQuery的js文件
- 使用
目前JQuery的三大版本
1.x
兼容ie678,使用最为广泛的,官方只做BUG维护,功能不在新增。因此一般项目来说,使用1.x版本就可以了,最终版本:1.12.4(2016年5月20日)
2.x
不兼容ie678,很少人使用,官方只做BUG维护,功能不在新增。如果不考虑兼容低版本的浏览器可以使用2.x。最终版本:2.2.4(2016年5月20日)
3.x
不兼容ie678,只支持最新的浏览器,除非特殊要求,一般不会使用3.x版本的,很多老的jQuery插件不支持这个版本。目前该版本是官方最要更新维护的版本
jquery-xxx.js与jquery-xxx.min.js区别
jquery-xxx.js
开发版本。给程序员看的,有良好的缩进和注释,体积会大一些
jquery-xxx.min.js
生产版本。程序中使用,没有缩进。体积下一些,程序加载更快
1 |
|
JQuery对象和JS对象区别与转换
JQuery对象在操作时,更加方便
JQuery对象和js对象方法不通用的
两者相互转换
jq–>js
jq对象[索引] 或者 jq对象.get(索引)
js–>jq
$(js对象)
1 |
|
选择器
筛选具有相似特征的元素(标签)
基本语法学习
事件绑定
获取id为b1按钮的点击事件
1 |
|
入口函数
如果js代码获取的对象在标签上面,就会加载不到,所以如果js代码写在标签上面,需要使用入口函数去解决这个问题
1 |
|
window.onload 和 $(function) 区别
- window.onload 只能定义一次,如果定义多次,后边的会将前边的覆盖掉
- $(function)可以定义多次的。
样式控制:css方法
1 |
|
基本选择器
标签选择器(元素选择器)
语法:$(“html标签名”)
获得所有匹配签名名称的元素
id选择器
语法:$(“#id的属性值”)
获得与指定id属性值匹配的元素
类选择器
语法:$(“.class的属性值”)
获得与指定的class属性值匹配的元素
并集选择器
语法:$(“选择器1,,选择器2…..”)
获取多个选择器选中的所有元素
1 |
|
层级选择器
后代选择器
语法:$(“A B”)
选择器A元素内部的所有B元素
子选择器
语法:$(“A > B”)
选择A元素内部的所有B子元素
1 |
|
属性选择器
下面的A就表示属性
属性名称选择器
语法:$(“A[属性名]”)
包含指定属性的选择器
属性选择器
语法:$(“A[属性值=’值’]”)
包含指定属性等于指定值的选择器
复合属性选择器
语法:$(“A[属性名=’值’] []…”)
包含多个属性条件的选择器
1 |
|
过滤选择器
首元素选择器
语法::first
获得选择的元素中的第一个元素
尾元素选择器
语法::last
获得选择的元素中的最后一个元素
非元素选择器
语法::not(selector)
不包括指定内容的元素
偶数选择器
语法::even 偶数
从0开始计数
奇数选择器
语法::odd 奇数
从0开始计数
等于索引选择器
语法::eq(index)
指定索引元素
大于索引选择器
语法::gt(index)
大于指定索引元素
小于索引选择器
语法::lt(index)
小于指定索引元素
标题选择器
语法::header
获得标题元素,固定写法
1 |
|
表单过滤选择器
元素选择器
语法::enabled
获得可用元素
不可用元素选择器
语法::disabled
获得不可用元素
选中选择器
语法::checked
获得单选/复选框选中的元素
选中选择器
语法::selected
获得下拉框选中的元素
1 |
|
DOM操作
内容操作
html()
获取/设置元素的标签体内容
1 |
|
text()
获取/设置元素的标签体纯文本内容
1 |
|
val()
获取/设置元素的value属性值
1 |
|
属性操作
通用属性操作
attr()
获取/设置元素的属性
removeAttr()
删除属性
prop()
获取/设置元素的属性
1 |
|
removeProp()
删除属性
attr和prop区别
- 如果操作的是元素的固有属性(对应w3c文档的元素中属性表格是否存在,存在则为固有属性),则建议使用prop
- 如果操作的是自定义的属性,则建议使用attr
对class属性操作
addClass()
添加class属性值
removeClass()
删除class属性值
toggleClass()
切换class属性
- toggleClass(“one”):判断如果元素对象上存在class=”one”,则将属性值one删除掉。如果元素对象上不存在class=”one”,则添加
1 |
|
CRUD操作
append()
父元素将子元素追加到末尾
对象1.append(对象2)
将对象2添加到对象1元素内部,并且在末尾
prepend()
父元素将子元素追加到开头
对象1.prepend(对象2)
将对象2添加到对象1元素内部,并且在开头
appendTo()
- 对象1.appendTo(对象2)
将对象1添加到对象2内部,并且在末尾
prependTo()
对象1.prependTo(对象2)
将对象1添加到对象2内部,并且在开头
after()
添加元素到元素后边
对象1.after(对象2)
将对象2添加到对象1后边。对象1和对象2是兄弟关系
before()
添加元素到元素前边
对象1.before(对象2)
将对象2添加到对象1前边。对象1和对象2是兄弟关系
insertAfter()
对象1.insertAfter(对象2)
将对象2添加到对象1后边。对象1和对象2是兄弟关系
insertBefore()
对象1.insertBefore(对象2)
将对象2添加到对象1前边。对象1和对象2是兄弟关系
remove()
移除元素
对象.remove()
将对象删除掉
1 |
|
empty()
清空元素的所有后代元素。
对象.empty()
将对象的后代元素全部清空,但是保留当前对象以及其属性节点
1 |
|
案例
隔行换色
1 |
|
全选全不选
1 |
|
表情选择
1 |
|
下拉选择条目左右移动
1 |
|
JQuery高级
动画
三种方式显示和隐藏元素
默认显示和隐藏的方式
- show( [speed] , [easing] , [fn] )
- speed:动画的速度,三个预定义的值(”slow”,”normal”,”fast”)或表示动画时长的毫秒数值(如:1000)
- easing:用来指定切换效果,默认是”swing”,可用参数”linear”
- swing:动画执行效果是,先慢,中间快,最后又慢
- linear:动画执行时,是匀速的
- fn:在动画完成时执行的函数,每个元素执行一次
- hide( [speed] , [easing] , [fn])
- toggle([speed], [easing] ,[fn])
滑动显示和隐藏方式
- slideDown([speed], [easing], [fn])
- slideUp([speed], [easing], [fn])
- slideToggle([speed], [easing], [fn])
淡入淡出显示和隐藏方式
- fadeIn([speed], [easing], [fn])
- fadeOut([speed], [easing], [fn])
- fadeToggle([speed], [easing], [fn])
1 |
|
遍历
Js的遍历方式
- for(初始值; 循环结束条件; 步长)
jq的遍历方式
- jq对象.each(callback)
- 语法:jq对象.each(function(index,element){});
- index:就是元素在集合中的索引
- element:就是集合中的每一个元素对象
- this:集合中的每一个元素对象
- 回调函数返回值
- true:如果当前function返回为false,则结束循环(break)
- false:如果当前function返回为itrue,则结束本次循环,继续下次循环(continue)
- 语法:jq对象.each(function(index,element){});
- $.each(object,[callback])
- for..of:jquery3.0版本之后提供的方式
- for(元素对象 of 容器对象)
1 |
|
事件绑定
标准的绑定方式
jq对象.事件方法(回调函数)
注意:如果调用事件方法,不传递回调函数,则会触发浏览器默认行为
表单对象.submit(); 让表单提交
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<script src="../js/jquery-3.3.1.min.js" type="text/javascript" charset="utf-8"></script>
<script type="text/javascript">
$(function () {
//1.获取name对象,绑定click事件
$("#name").click(function () {
alert("我被点击了...")
});
//给name绑定鼠标移动到元素之上事件。绑定鼠标移出事件
$("#name").mouseover(function () {
alert("鼠标来了...")
});
$("#name").mouseout(function () {
alert("鼠标走了...")
});
//简化操作,链式编程
$("#name").mouseover(function () {
alert("鼠标来了...")
}).mouseout(function () {
alert("鼠标走了...")
});
alert("我要获得焦点了...")
//$("#name").focus();//让文本输入框获得焦点
//表单对象.submit();//让表单提交
});
</script>
</head>
<body>
<input id="name" type="text" value="绑定点击事件">
</body>
</html>
on绑定事件/off解除绑定
- jq对象.on(“事件名称”,回调函数)
- jq对象.off(“事件名称”)
- 如果off方法不传递任何参数,则将组件上的所有事件全部解绑
1 |
|
事件切换(toggle)
jq对象.toggle(fn1, fn2…)
- 当单击jq对象对应的组件后,会执行fn1,第二次点击会执行fn2…
注意:1.9版本,toggle()方法删除,jquery Migrate(迁移)插件可以恢复此功能
1 |
|
1 |
|
案例
广告的显示和隐藏
需求:
- 当页面加载完,3秒后,自动显示广告
- 广告显示5秒后,自动消失
1 |
|
抽奖
1 |
|
插件
增强JQuery的功能
实现方式
$.fn.extend(object)
增强通过jquery获取的对象的功能 $(“#id”)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>01-jQuery对象进行方法扩展</title>
<script src="../js/jquery-3.3.1.min.js" type="text/javascript" charset="utf-8"></script>
<script type="text/javascript">
//使用jquery插件 给jq对象添加2个方法 check()选中所有复选框,uncheck()取消选中所有复选框
//1.定义jqeury的对象插件
$.fn.extend({
//定义了一个check()方法。所有的jq对象都可以调用该方法
check:function () {
//让复选框选中
//this:调用该方法的jq对象
this.prop("checked",true);
},
uncheck:function () {
//让复选框不选中
this.prop("checked",false);
}
});
$(function () {
// 获取按钮
//$("#btn-check").check();
//复选框对象.check();
$("#btn-check").click(function () {
//获取复选框对象
$("input[type='checkbox']").check();
});
$("#btn-uncheck").click(function () {
//获取复选框对象
$("input[type='checkbox']").uncheck();
});
});
</script>
</head>
<body>
<input id="btn-check" type="button" value="点击选中复选框" onclick="checkFn()">
<input id="btn-uncheck" type="button" value="点击取消复选框选中" onclick="uncheckFn()">
<br/>
<input type="checkbox" value="football">足球
<input type="checkbox" value="basketball">篮球
<input type="checkbox" value="volleyball">排球
</body>
</html>$.extend(object)
增强Jquery对象自身的功能 $/JQuery
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>01-jQuery对象进行方法扩展</title>
<script src="../js/jquery-3.3.1.min.js" type="text/javascript" charset="utf-8"></script>
<script type="text/javascript">
//对全局方法扩展2个方法,扩展min方法:求2个值的最小值;扩展max方法:求2个值最大值
$.extend({
max:function (a,b) {
//返回两数中的较大值
return a >= b ? a:b;
},
min:function (a,b) {
//返回两数中的较小值
return a <= b ? a:b;
}
});
//调用全局方法
var max = $.max(4,3);
//alert(max);
var min = $.min(1,2);
alert(min);
</script>
</head>
<body>
</body>
</html>