-
基本概念
-
选择器
-
样式操作
-
动画
-
属性操作
-
事件机制
-
jQuery插件机制
-
jQuery封装(面向对象)
1. jQuery基本介绍
1.1 为什么要学jQuery
使用JS操作DOM的时候,会遇到以下的一些缺点:
//1. 获取元素的方法太少且长,麻烦。
//2. 遍历伪数组很麻烦,通常要嵌套一大堆的for循环。
//3. 注册的事件会覆盖。
//4. 有兼容性问题。
//5. 实现动画很麻烦
1.2 初体验
$(document).ready(function () {
$("#btn1").click(function () {
//隐式迭代:偷偷的遍历,在jQuery中,不需要手动写for循环了,会自动进行遍历。
$("div").show(200);
});
$("#btn2").click(function () {
$("div").text("我是内容");
});
});
使用jQuery的优点 :
//1. 获取元素的方式非常的简单,而且非常的丰富
//2. jQuery的隐式迭代特性,不再需要书写for循环语句。
//3. 使用jQuery完全不用考虑兼容性问题。
//4. jQuery提供了一系列动画相关的函数,使用非常方便。
//5. 代码简单、粗暴。
1.3 什么是jQuery?
jQuery是一个快速的、轻量的、功能丰富的js库。
jQuery的官网 http://jquery.com/
jQuery就是一个js库,使用jQuery的话,会比使用JavaScript更简单。
js库:把一些常用到的方法写到一个单独的js文件,使用的时候直接去引用这js文件就可以了。(animate.js、common.js)
1.4 使用步骤
引包(引入js文件)
<script src="jquery-1.11.1.js"></script>
入口函数
$(document).ready(function () {
});
$(function(){
});
功能实现
$("#btnShowDiv").click(function () {
$("div").show(1000);
});
1.5 版本介绍
官网下载地址:http://jquery.com/download/
jQuery版本有很多,分为1.x 2.x 3.x
大版本分类:
1.x版本:能够兼容IE678浏览器(最终版本1.12.4)
2.x版本:不兼容IE678浏览器(最终版本2.2.4)
//jQuery目前正在更新的版本
3.x版本:不兼容IE678,更加的精简(在国内不流行,因为国内使用jQuery的主要目的就是兼容IE678),3.x版本只是在原来的基础上增加了一些新的特性。
关于压缩版和未压缩版 :
jquery-1.12.4.min.js:压缩版本,适用于生产环境,因为文件比较小,去除了注释、换行、空格等东西,但是基本没有可阅读性。
jquery-1.12.4.js:未压缩版本,适用于学习与开发环境,源码清晰,易阅读。
1.6 入口函数
入口函数的好处:
1. 等待文档加载完成,保证能够获取到元素
2. 形成了一个沙箱,防止全局变量污染。
两种写法:
//第一种写法
$(document).ready(function() {
});
//第二种写法
$(function() {
});
//js入口函数
window.onload = function(){
...
}
jQuery入口函数与js入口函数的对比 :
1. JavaScript的入口函数要等到页面中所有资源(包括图片、文件)加载完成才开始执行。
2. jQuery的入口函数只会等待文档树加载完成就开始执行,并不会等待图片、文件的加载。
1.7 jQuery对象与DOM对象(重点)
基本概念:
1. DOM对象:使用JavaScript中的方法获取页面中的元素返回的对象就是dom对象。
2. jQuery对象:jquery对象就是使用jquery的方法获取页面中的元素返回的对象就是jQuery对象。
3. jQuery对象其实就是DOM对象的包装集(包装了DOM对象的集合(伪数组))
jQuery对象与DOM对象的区别:
1. DOM对象与jQuery对象的方法不能混用。
2. DOM对象可以和jQuery对象相互转化
// dom对象
通过原生js方法获取到的元素就是dom对象
document.getElementById、document.getElementsByTagName
dom对象只能使用dom对象本身的属性和方法,不能使用jq提供的方法
// jq对象
通过jq提供的$() 方法获取到的元素就是jq对象
jq对象是一个伪数组,伪数组里面以下标的形式存储着获取到所有的dom对象
jq对象只能使用jq提供的方法,不能使用dom对象的方法
DOM对象转换成jQuery对象:【联想记忆:花钱】
var $obj = $(domObj);
// $(document).ready(function(){});就是典型的DOM对象转jQuery对象
jQuery对象转换成DOM对象:
var $li = $(“li”);
//第一种方法(推荐使用)
$li[0]
//第二种方法
$li.get(0)
// $: 哪里来,jq文件提供的
// $: 是个函数
// $的作用
// 功能比较强大,参数不同,作用就不同
// 1. 参数是函数, $(function(){}),, 作用是入口函数
// 2. 参数是选择器,$("div"),, 作用是获取页面上的元素
// 3. 参数是dom对象 $(document) 作用是dom对象转jq对象
隔行变色案例:
<script src="./jquery-1.12.4.js"></script>
<script>
$(function(){
/*var lis = document.getElementsByTagName("li");
for(var i = 0; i < lis.length; i++){
if(i % 2 === 0){
lis[i].style.backgroundColor = "hotpink";
}else{
lis[i].style.backgroundColor = "yellow";
}
}*/
var lis = $("li"); // jq对象
for(var i = 0; i < lis.length; i++){
if(i % 2 === 0){
// lis[i]: dom对象
lis[i].style.backgroundColor = "hotpink";
}else{
// lis[i].style.backgroundColor = "yellow";
lis.get(i).style.backgroundColor = "yellow";
}
}
})
</script>
开关灯案例:
<script src="./jquery-1.12.4.js"></script>
<script>
$(function(){
$("#btn1").click(function(){
// 改变的是body的样式
document.body.style.backgroundColor = "#fff";
})
$("#btn2").click(function(){
// 改变的是body的样式
// document.body.style.backgroundColor = "#000";
// css() : 设置和获取元素的样式
// css(name, value); name 是样式, value是样式值
$("body").css("backgroundColor", "#000");
})
})
</script>
2. 选择器
2.1 什么是jQuery选择器
jQuery选择器是jQuery为我们提供的一组方法,让我们更加方便的获取到页面中的元素。注意:jQuery选择器返回的是jQuery对象。
jQuery选择器有很多,基本兼容了CSS1到CSS3所有的选择器,并且jQuery还添加了很多更加复杂的选择器。【查看jQuery文档】
jQuery选择器虽然很多,但是选择器之间可以相互替代,就是说获取一个元素,你会有很多种方法获取到。所以我们平时真正能用到的只是少数的最常用的选择器。
2.2 css选择器
jQuery完全兼容css选择器
名称 | 用法 | 描述 |
---|---|---|
ID选择器 | $(“#id”); | 获取指定ID的元素 |
类选择器 | $(“.class”); | 获取同一类class的元素 |
标签选择器 | $(“div”); | 获取同一类标签的所有元素 |
并集选择器 | $(“div,p,li”); | 使用逗号分隔,只要符合条件之一就可。 |
交集选择器 | $(“div.redClass”); | 获取class为redClass的div元素 |
子代选择器 | $(“ul>li”); | 使用>号,获取儿子层级的元素,注意,并不会获取孙子层级的元素 |
后代选择器 | $(“ul li”); | 使用空格,代表后代选择器,获取ul下的所有li元素,包括孙子等 |
跟CSS的选择器一模一样。
2.3 过滤选择器
这类选择器都带冒号:
名称 | 用法 | 描述 |
---|---|---|
:eq(index) | $(“li:eq(2)”).css(“color”, ”red”); | 获取到的li元素中,选择索引号为2的元素,索引号index从0开始。 |
:odd | $(“li:odd”).css(“color”, ”red”); | 获取到的li元素中,选择索引号为奇数的元素 |
:even | $(“li:even”).css(“color”, ”red”); | 获取到的li元素中,选择索引号为偶数的元素 |
:first | $(“li:first”).css(“color”, ”red”); | 获取到的li元素中的第一个 |
:last | $(“li:last”).css(“color”, ”red”); | 获取到的li元素中的最后一个 |
2.4 筛选选择器(方法)
筛选选择器的功能与过滤选择器有点类似,但是用法不一样,筛选选择器
主要是方法。
名称 | 用法 | 描述 |
---|---|---|
children(selector) | $(“ul”).children(“li”) | 获取当前元素的所有子元素中的li元素 |
find(selector) | $(“ul”).find(“li”); | 获取当前元素中的后代元素中的li元素 |
siblings(selector) | $(“#first”).siblings(“li”); | 查找兄弟节点,不包括自己本身。 |
parent() | $(“#first”).parent(); | 查找父亲 |
eq(index) | $(“li”).eq(2); | 相当于$(“li:eq(2)”) ,index从0开始 |
next() | $(“li”).next() | 找下一个兄弟 |
prev() | $(“li”).prev() | 找上一个兄弟 |
//【案例:下拉菜单】this+children+mouseenter+mouseleave
//【案例:突出展示】siblings+find
//【案例:手风琴】next+parent
//【案例:淘宝精品】index+eq
3. 其他补充
3.1 mouseover与mouseenter
mouseover和mouseoverenter都有鼠标经过的意思,但是在注册鼠标经过事件的时候,推荐使用mouseenter
(http://www.w3school.com.cn/tiy/t.asp?f=jquery_event_mouseenter_mouseover)
-
mouseover与mouseout是一对事件,当鼠标经过当前元素或者当前元素的子元素的时候,mouseover事件都会触发【事件冒泡】。
-
mouseenter与mouseleave是一对事件,只有当鼠标经过当前元素时,事件会触发,鼠标经过子元素,mousenter事件是不会触发的。
3.2 index方法
index()
方法返回的是当前元素在所有兄弟元素里面的索引。
<ul>
<li><a href="#">我是链接</a></li>
<li><a href="#">我是链接</a></li>
<li><a href="#">我是链接</a></li>
<li><a href="#">我是链接</a></li>
<li><a href="#">我是链接</a></li>
<li><a href="#">我是链接</a></li>
<li><a href="#">我是链接</a></li>
<li><a href="#">我是链接</a></li>
<li><a href="#">我是链接</a></li>
</ul>
当碰到这种结构的时候,推荐给li注册事件,这样通过index方法才能获取到正确的索引值。
3.3 区分jQuery与Javascript
JavaScript是一门编程语言,jQuery仅仅是用JavaScript实现的一个JavaScript库,目的是简化我们的开发。(联想记忆:不能扛着洗衣机去出差)
4. jQuery操作样式
4.1 css操作
功能:设置或者修改样式,操作的是style属性。
操作单个样式:
//name:需要设置的样式名称
//value:对应的样式值
css(name, value);
//使用案例
$("#one").css("background","gray");//将背景色修改为灰色
设置多个样式:
//参数是一个对象,对象中包含了需要设置的样式名和样式值
css(obj);
//使用案例
$("#one").css({
"background":"gray",
"width":"400px",
"height":"200px"
});
获取样式 :
//name:需要获取的样式名称
css(name);
//案例
$("div").css("background-color");
注意:获取样式操作只会返回第一个元素对应的样式值。
隐式迭代:
-
设置操作的时候,如果是多个元素,那么给所有的元素设置相同的值
-
获取操作的时候,如果是多个元素,那么只会返回第一个元素的值。
4.2 class操作
添加样式类 :
//name:需要添加的样式类名,注意参数不要带点.
addClass(name);
//例子,给所有的div添加one的样式。
$(“div”).addClass(“one”);
移除样式类 :
//name:需要移除的样式类名
removeClass(“name”);
//例子,移除div中one的样式类名
$(“div”).removeClass(“one”);
判断是否有某个样式类 :
//name:用于判断的样式类名,返回值为true false
hasClass(name)
//例子,判断第一个div是否有one的样式类
$(“div”).hasClass(“one”);
切换样式类 :
//name:需要切换的样式类名,如果有,移除该样式,如果没有,添加该样式。
toggleClass(name);
//例子
$(“div”).toggleClass(“one”);
【案例:tab栏切换案例.html】
5. jQuery操作属性
5.1 attr操作
设置单个属性
//第一个参数:需要设置的属性名
//第二个参数:对应的属性值
attr(name, value);
//用法举例
$(“img”).attr(“title”,”哎哟,不错哦”);
$(“img”).attr(“alt”,“哎哟,不错哦”);
设置多个属性
//参数是一个对象,包含了需要设置的属性名和属性值
attr(obj)
//用法举例
$("img").attr({
title:"哎哟,不错哦",
alt:"哎哟,不错哦",
style:"opacity:.5"
});
获取属性
//传需要获取的属性名称,返回对应的属性值
attr(name)
//用法举例
var oTitle = $("img").attr("title");
alert(oTitle);
移除属性
//参数:需要移除的属性名,
removeAttr(name);
//用法举例
$("img").removeAttr("title");
【案例:美女相册.html】
5.2 prop操作
在jQuery1.6之后,对于checked、selected、disabled这类boolean类型的属性来说,不能用attr方法,只能用prop方法。
//设置属性
$(“:checked”).prop(“checked”,true);
//获取属性
$(“:checked”).prop(“checked”);//返回true或者false
【案例:表格全选案例.html】
// 标签上的自定义属性用attr方法
// 标签固有的属性用prop方法(src,title, checked, disabled, selected, width)
// 使用建议:attr方法使用的比较多,但是对于checked, disabled, selected只能使用prop方法
6. jQuery动画
jquery提供了三组基本动画,这些动画都是标准的、有规律的效果,jquery还提供了自定义动画的功能。【演示动画例子】
6.1 三组基本动画
显示(show)与隐藏(hide)是一组动画:
滑入(slideUp)与滑出(slideDown)与切换(slideToggle),效果与卷帘门类似
淡入(fadeIn)与淡出(fadeOut)与切换(fadeToggle)
show([speed], [callback]);
//speed(可选):动画的执行时间
//1.如果不传,就没有动画效果。如果是slide和fade系列,会默认为normal
//2.毫秒值(比如1000),动画在1000毫秒执行完成(推荐)
//3.固定字符串,slow(200)、normal(400)、fast(600),如果传其他字符串,则默认为normal。
//callback(可选):执行完动画后执行的回调函数
// show(speed, easing, callback)
// hide(speed, easing, callback)
// toggle(speed, easing, callback)
// 不传参,就没有动画效果
// 主要修改的时候元素的width、height、opacity
// 三个参数都是可选的
// 参数:
// speed: 动画时长,单位是ms,默认还提供了三个字符串的值,可选
// "slow": 600
// "normal": 400
// "fast": 200
// 如果传递的是除了上面三个之外的字符串,取normal
// easing: 动画效果,默认值是swing(秋千,慢-快-慢),linear(匀速),可选
// callback: 动画结束的时候来执行的函数,可选
$("button").eq(0).click(function(){
$("div").show(1000, function(){
console.log("show 动画结束了");
});
})
【案例:下拉菜单动画版.html】
【案例:京东轮播图(呼吸灯).html】
6.2 自定义动画
animate: 自定义动画
$(selector).animate({params},[speed],[easing],[callback]);
// {params}:要执行动画的CSS属性,带数字(必选)
// speed:执行动画时长(可选)
// easing:执行效果,默认为swing(缓动) 可以是linear(匀速)
// callback:动画执行完后立即执行的回调函数(可选)
6.3 动画队列与停止动画
在同一个元素上执行多个动画,那么对于这个动画来说,后面的动画会被放到动画队列中,等前面的动画执行完成了才会执行(联想:火车进站)。
//stop方法:停止动画效果
stop(clearQueue, jumpToEnd);
//第一个参数:是否清除队列
//第二个参数:是否跳转到最终效果
// 有默认值,两个都是false
【案例:手风琴特效】
【案例:音乐导航】
7. jQuery节点操作
7.1 创建节点
//$(htmlStr)
//htmlStr:html格式的字符串
$(“<span>这是一个span元素</span>”);
7.2 添加节点
//append appendTo
//prepend prependTo
//before
//after
// append: 对appendChild() 的封装
// A.append(B); 把B元素添加到A元素里面去,作为最后一个子元素
// $("div").append( $(".outerP") ); // 页面上存在的元素,会是剪切的效果
// $("div").append( '<p class="outerP">这是div外的p元素</p>' ); // 参数可以是html字符串,先创建元素,在去添加
// appendTo
// B.appendTo(A); 把B元素添加到A元素里面去,作为最后一个子元素
// $(".outerP").appendTo( $("div") );
// $(".outerP").appendTo( "div" ); // 参数可以是选择器,先找到这个元素,在去将B添加到A
// prepend
// A.prepend(B); 把B元素添加到A元素里面去,作为第一个子元素
// $("div").prepend( $(".outerP") );
// $("div").prepend('<p class="outerP">这是div外的p元素</p>');
// prependTo()
// B.prependTo(A); 把B元素添加到A元素里面去,作为第一个子元素
// $(".outerP").prependTo( $("div") );
// $(".outerP").prependTo( "div" );
// after、before()
// after()
// A.after(B); 让B元素作为A的兄弟元素,并且放在A的后面
// $("div").after( $(".innerP") );
// before()
// A.before(B); 让B元素作为A的兄弟元素,并且放在A的前面
【案例:城市选择案例.html】
7.3 清空节点与删除节点
empty:清空指定节点的所有元素,自身保留(清理门户)
$(“div”).empty();//清空div的所有内容(推荐使用,会清除子元素上绑定的内容,源码)
$(“div”).html(“”);//使用html方法来清空元素,不推荐使用,会造成内存泄漏,绑定的事件不会被清除。
remove:相比于empty,自身也删除(自杀)
$(“div”).remove();
7.4 克隆节点
作用:复制匹配的元素
// 复制$(selector)所匹配到的元素(深度复制)
//cloneNode(true)
// 返回值为复制的新元素,和原来的元素没有任何关系了。即修改新元素,不会影响到原来的元素。
$(selector).clone();
【案例:微博发布】
【案例:弹幕效果】
8. jQuery特殊属性操作
8.1. val方法
val方法用于设置和获取表单元素的值,例如input、textarea的值
//设置值
$("#name").val(“张三”);
//获取值
$("#name").val();
【案例:京东搜索.html】
8.2. html方法与text方法
html方法相当于innerHTML text方法相当于innerText
//设置内容
$(“div”).html(“<span>这是一段内容</span>”);
//获取内容
$(“div”).html()
//设置内容
$(“div”).text(“<span>这是一段内容</span>”);
//获取内容
$(“div”).text()
区别:html方法会识别html标签,text方法会那内容直接当成字符串,并不会识别html标签。
8.3. width方法与height方法
设置或者获取高度
//带参数表示设置高度
$(“img”).height(200);
//不带参数获取高度
$(“img”).height();
获取网页的可视区宽高
//获取可视区宽度
$(window).width();
//获取可视区高度
$(window).height();
// width/height() width
// 获取元素的宽高
// 设置:传参
// innerWidth(); padding + width
console.log($("div").innerWidth());
// outerWidth(); border + padding + width
// 可以传参,参数为true, 默认值是false
console.log($("div").outerWidth());
// outerWidth(true); margin + border + padding + width
console.log($("div").outerWidth(true));
8.4. scrollTop与scrollLeft
设置或者获取垂直滚动条的位置
//获取页面被卷曲的高度
$(window).scrollTop();
//获取页面被卷曲的宽度
$(window).scrollLeft();
【案例:仿腾讯固定菜单栏案例】 【案例:小火箭返航案例】
8.5. offset方法与position方法
offset方法获取元素距离document的位置,position方法获取的是元素距离有定位的父元素的位置。
//获取元素距离document的位置,返回值为对象:{left:100, top:100}
$(selector).offset();
//获取相对于其最近的有定位的父元素的位置。
$(selector).position();
9. jQuery事件机制
JavaScript中已经学习过了事件,但是jQuery对JavaScript事件进行了封装,增加并扩展了事件处理机制。jQuery不仅提供了更加优雅的事件处理语法,而且极大的增强了事件的处理能力。
9.1. jQuery事件发展历程(了解)
简单事件绑定>>bind事件绑定>>delegate事件绑定>>on事件绑定(推荐)
简单事件注册
click(handler) 单击事件 mouseenter(handler) 鼠标进入事件 mouseleave(handler) 鼠标离开事件
缺点:不能同时注册多个事件
bind方式注册事件
//第一个参数:事件类型
//第二个参数:事件处理程序
$("p").bind("click mouseenter", function(){
//事件响应方法
});
缺点:不支持动态事件绑定
delegate注册委托事件
// 第一个参数:selector,要绑定事件的元素
// 第二个参数:事件类型
// 第三个参数:事件处理函数
$(".parentBox").delegate("p", "click", function(){
//为 .parentBox下面的所有的p标签绑定事件
});
缺点:只能注册委托事件,因此注册时间需要记得方法太多了
on注册事件
9.2. on注册事件(重点)
jQuery1.7之后,jQuery用on统一了所有事件的处理方法。
最现代的方式,兼容zepto(移动端类似jQuery的一个库),强烈建议使用。
on注册简单事件
// 表示给$(selector)绑定事件,并且由自己触发,不支持动态绑定。
$(selector).on( "click", function() {});
on注册委托事件
// 表示给$(selector)绑定代理事件,当必须是它的内部元素span才能触发这个事件,支持动态绑定
$(selector).on( "click",“span”, function() {});
on注册事件的语法:
// 第一个参数:events,绑定事件的名称可以是由空格分隔的多个事件(标准事件或者自定义事件)
// 第二个参数:selector, 执行事件的后代元素(可选),如果没有后代元素,那么事件将有自己执行。
// 第三个参数:data,传递给处理函数的数据,事件触发的时候通过event.data来使用(不常使用)
// 第四个参数:handler,事件处理函数
$(selector).on(events[,selector][,data],handler);
9.3. 事件解绑
unbind方式(不用)
$(selector).unbind(); //解绑所有的事件
$(selector).unbind("click"); //解绑指定的事件
undelegate方式(不用)
$( selector ).undelegate(); //解绑所有的delegate事件
$( selector).undelegate( “click” ); //解绑所有的click事件
off方式(推荐)
// 解绑匹配元素的所有事件
$(selector).off();
// 解绑匹配元素的所有click事件
$(selector).off("click");
9.4. 触发事件
$(selector).click(); //触发 click事件
$(selector).trigger("click");
9.5. jQuery事件对象
jQuery事件对象其实就是js事件对象的一个封装,处理了兼容性。
//screenX和screenY 对应屏幕最左上角的值
//clientX和clientY 距离页面左上角的位置(忽视滚动条)
//pageX和pageY 距离页面最顶部的左上角的位置(会计算滚动条的距离)
//event.keyCode 按下的键盘代码
//event.data 存储绑定事件时传递的附加数据
//event.stopPropagation() 阻止事件冒泡行为
//event.preventDefault() 阻止浏览器默认行为
//return false:既能阻止事件冒泡,又能阻止浏览器默认行为。
【案例:钢琴版导航(加强).html】
10. jQuery补充知识点
10.1. 链式编程
通常情况下,只有设置操作才能把链式编程延续下去。因为获取操作的时候,会返回获取到的相应的值,无法返回 jQuery对象。
end(); // 筛选选择器会改变jQuery对象的DOM对象,想要回复到上一次的状态,并且返回匹配元素之前的状态。
【案例:五角星评分案例.html】
10.2. each方法
jQuery的隐式迭代会对所有的DOM对象设置相同的值,但是如果我们需要给每一个对象设置不同的值的时候,就需要自己进行迭代了。
作用:遍历jQuery对象集合,为每个匹配的元素执行一个函数
// 参数一表示当前元素在所有匹配元素中的索引号
// 参数二表示当前元素(DOM对象)
$(selector).each(function(index,element){});
【案例:不同的透明度.html】
10.3. 多库共存
jQuery使用$作为标示符,但是如果与其他框架中的$冲突时,jQuery可以释放$符的控制权.
var c = $.noConflict();//释放$的控制权,并且把$的能力给了c