jQuery
1、jQuery的概念
总体概述如下
- jQuery是一个快速、简洁的JavaScript库,其设计的宗旨是“write Less,Do More”,即倡导写更少的代码,做更多的事情。
- j就是JavaScript;Query:查询,意思就是查询js,把js中的DOM操作做了封装,我们可以快速的查询使用里面的功能。
- jQuery封装了JavaScript常用的功能代码,优化了DOM操作、事件处理、动画设计和Ajax交互。
- 学习jQuery本质:就是学习调用这些函数(方法)。
- jQuery出现的目的是加快前端人员的开发速度,我们可以非常方便的调用和使用它,从而提高开发速率。
2、jQuery的优点
- 轻量级。核心文件才几十kb,不会影响页面加载速度。
- 跨浏览器兼容,基本兼容了现在主流的浏览器。
- 链式编程、隐式迭代。
- 对事件、样式、动画支持,大大简化了DOM操作。
- 支持插件扩展开发。有着丰富的第三方的插件,例如:树形菜单、日期控件、轮播图等。
- 免费、开源。
3、jQuery的入口函数
// 第一种: 简单易用。
$(function () {
... // 此处是页面 DOM 加载完成的入口
}) ;
// 第二种: 繁琐,但是也可以实
$(document).ready(function(){
... // 此处是页面DOM加载完成的入口
});
4、jQuery中的顶级对象$
- 是 j Q u e r y 的别称, 是jQuery的别称, 是jQuery的别称,()函数是jQuery()函数的别称。在代码中可以使用jQuery代替,但一般为了方便,通常都直接使用$
- 是 j Q u e r y 的顶级对象,相当于原生 J a v a S c r i p t 中的 w i n d o w 。把元素利用 是jQuery的顶级对象,相当于原生JavaScript中的window。把元素利用 是jQuery的顶级对象,相当于原生JavaScript中的window。把元素利用包装成jQuery对象,就可以调用jQuery的方法。
5、如果其他 JavaScript 框架也使用 $ 符号作为简写怎么办?(多库共存)
可以使用jQuery noConflict() 方法
noConflict() 方法会释放会 $ 标识符的控制,这样其他脚本就可以使用它了。
实现方式1:
//可以通过全名替代简写的方式来使用 jQuery:
$.noConflict();
jQuery(document).ready(function(){
jQuery("button").click(function(){
jQuery("p").text("jQuery 仍在运行!");
});
});
实现方式2:
//可以创建自己的简写。noConflict() 可返回对 jQuery 的引用,您可以把它存入变量,以供稍后使用。
var jq = $.noConflict();
jq(document).ready(function(){
jq("button").click(function(){
jq("p").text("jQuery 仍在运行!");
});
});
实现方式3:
//不愿意改变这个快捷方式,可以把 $ 符号作为变量传递给 ready 方法。这样就可以在函数内使用 $ 符号了 - 而在函数外,依旧不得不使用 "jQuery"
$.noConflict();
jQuery(document).ready(function($){
$("button").click(function(){
$("p").text("jQuery 仍在运行!");
});
});
6、jQuery对象和DOM对象
使用jQuery方法和原生JS获取的元素是不一样的,总结如下:
- 用原生JS获取来的对象就是DOM对象。
- jQuery方法获取来的元素就是jQuery对象。
- jQuery对象本质是:利用$对DOM对象包装后产生的对象(为数组形势存储)。
7、jQuery对象和DOM对象转换
DOM对象与jQuery对象之间是可以相互转换的。因为原生js比jQuery更大,原生的一些属性和方法jQuery没有给我们封装, 更想使用这些属性和方法把jQuery对象转换为DOM对象才能使用。
// 1.DOM对象转换成jQuery对象,方法只有一种
var box = document.getElementById('box'); // 获取DOM对象
var jQueryObject = $(box); // 把DOM对象转换为 jQuery 对象
// 2.jQuery 对象转换为 DOM 对象有两种方法:
// 2.1 jQuery对象[索引值]
var domObject1 = $('div')[0]
// 2.2 jQuery对象.get(索引值)
var domObject2 = $('div').get(0)
总结:实际开发比较常用的是把DOM对象转换为jQuery对象,这样能够调用功能更加强大的jQuery中的方法。
8、说一说你知道的jQuery选择器有哪些?
$("选择器") // 里面选择器直接写 CSS 选择器即可,但是要加引号
- 基本选择器:直接根据id、CSS类名、元素名返回匹配的DOM元素。
- 层级选择器:也叫做路径选择器,可以根据路径层次来选择相应的DOM元素。parent > child,prev + next, prev ~siblings
- 表单选择器: :input ,:text ,:password ,:raido ,:checkbox ,:submit等
- 过滤选择器: 在前面的基础上过滤相关条件,得到匹配的DOM元u尿素。基本过滤选择器: :first , :last ,:not ,:even ,:odd ,:eq ,:gt ,:lt 内容过滤器选择器: :hidden , :visible。属性过滤器选择器 :[attribute] ,[attribute=value],子元素过滤器选择器: :nth-child, :first-child ,:last-child , :only-child 。**表单过滤选择器: ** :enabled, :disabled , :checked ,:selected。
9、jQuery中的选择器和css中的选择器有区别吗?
- jQuery选择器支持CSS里的选择器。
- jQuery选择器可用来添加样式和添加相应的行为。
- CSS中的选择器是只能添加相应的样式。
10、jQuery 样式操作
jQuery中常用的样式操作有两种:css() 和 设置类样式方法
方法1: 操作 css 方法
jQuery 可以使用 css 方法来修改简单元素样式; 也可以操作类,修改多个样式。
常用以下三种形式 :
// 1.参数只写属性名,则是返回属性值
var strColor = $(this).css('color');
// 2. 参数是属性名,属性值,逗号分隔,是设置一组样式,属性必须加引号,值如果是数字可以不用跟单位和引号
$(this).css(''color'', ''red'');
// 3. 参数可以是对象形式,方便设置多组样式。属性名和属性值用冒号隔开, 属性可以不用加引号
$(this).css({ "color":"white","font-size":"20px"});
注意:css() 多用于样式少时操作,多了则不太方便。
方法2: 设置类样式方法
作用等同于以前的 classList,可以操作类样式, 注意操作类里面的参数不要加点。
常用的三种设置类样式方法:
// 1.添加类
$("div").addClass("current");
// 2.删除类
$("div").removeClass("current");
// 3.切换类
$("div").toggleClass("current");
注意:
- 设置类样式方法比较适合样式多时操作,可以弥补css()的不足。
- 原生 JS 中 className 会覆盖元素原先里面的类名,jQuery 里面类操作只是对指定类进行操作,不影响原先的类名。
11、jQuery中如何来获取或和设置属性?
- jQuery 中可以用 attr()方法来获取和设置元素属性
- 用 removeAttr() 方法来删除元素属性
- data() 方法可以在指定的元素上存取数据,并不会修改 DOM 元素结构。一旦页面刷新,之前存放的数据都将被移除。 设置 ( " s p a n " ) . d a t a ( " u n a m e " , " a n d y " ) ; 获取 ("span").data("uname", "andy");获取 ("span").data("uname","andy");获取(“span”).data(“uname”)
- 元素固有属性值 prop(),所谓元素固有属性就是元素本身自带的属性,比如 元素里面的 href ,比如 元素里面的 type。
12、jQuery中遍历节点的常用方法
children()
获取子元素,只考虑子元素不考虑后代元素next()
获取下一个紧邻的兄弟元素prev()
获取上一个紧邻的兄弟元素siblings()
获取当前元素的所有兄弟元素(除了自己)parents()
获取当前元素的所有祖先元素。find()
取得匹配元素中的元素集合 包括子代和后代
13、${document}.readey()是个什么函数?为什么要用它?
ready()函数用于在文档进入ready状态时执行代码。当DOM完全加载(例如HTML被完全解析DOM树构建完成时),jQuery允许你执行代码。使用$(document).ready()的最大好处在于它适用于所有浏览器,jQuery帮你解决乐跨浏览器的难题。
14、JS 的window.onload事件和jQuery ready函数有何不同?
JavaScript window.onload 事件和 jQuery ready 函数之间的主要区别是,前者除了要等待 DOM 被创建还要等到包括大型图片、音频、视频在内的所有外部资源都完全加载。如果加载图片和媒体内容花费了大量时间,用户就会感受到定义在 window.onload 事件上的代码在执行时有明显的延迟。jQuery ready() 函数只需对 DOM 树的等待,而无需对图像或外部资源加载的等待,从而执行起来更快。
另 一方面,使用 jQuery $(document).ready() 的另一个优势是你可以在网页里多次使用它,浏览器会按它们在 HTML 页面里出现的顺序执行它们,相反对于 onload 技术而言,只能在单一函数里使用。鉴于这个好处,用 jQuery ready() 函数比用 JavaScript window.onload 事件要更好些。
15、哪种方式更高效:document.getElementbyId(“myId”) 还是 $(“#myId”)?
第一种,因为它直接调用了 JavaScript 引擎。
16、 jQuery 中$(this) 和 this 关键词有何不同?
- $(this) 返回一个 jQuery 对象,你可以对它调用多个 jQuery 方法,比如用 text() 获取文本,用val() 获取值等等。
- this 代表当前元素,它是 JavaScript 关键词中的一个,表示上下文中的当前 DOM 元素。你不能对它调用 jQuery 方法,直到它被 $() 函数包裹,例如 $(this)。
17、说一说你了解的动画效果方法
jQuery 给我们封装了很多动画效果,最为常见的如下:
- 显示隐藏:show() / hide() / toggle() ;
- 划入画出:slideDown() / slideUp() / slideToggle() ;
- 淡入淡出:fadeIn() / fadeOut() / fadeToggle() / fadeTo() ;
- 自定义动画:animate() ;
注意:
动画或者效果一旦触发就会执行,如果多次触发,就造成多个动画或者效果排队执行。
jQuery为我们提供另一个方法,可以停止动画排队:stop() ;
显示隐藏,show() / hide() / toggle()3个参数都一样
show([spedd, [easing], [fn] ])
- 参数都可以省略,无动画直接显示。
- speed: 三种预定速度之一的字符串(“slow”,“normal”,or “fast”)或表示动画时长的毫秒值(如: 1000)。
- easing: (Optional)用来指定切换效果,默认是"swing",可用参数(linear)
- fn:回调函数,在动画完成时执行的函数,每个元素执行一次。
<body>
<button>显示</button>
<button>隐藏</button>
<button>切换</button>
<div></div>
<script>
$(function() {
$("button").eq(0).click(function() {
$("div").show(1000, function() {
alert(1);
});
})
$("button").eq(1).click(function() {
$("div").hide(1000, function() {
alert(1);
});
})
$("button").eq(2).click(function() {
$("div").toggle(1000);
})
// 一般情况下,我们都不加参数直接显示隐藏就可以了
});
</script>
</body>
滑入滑出,slideDown() / slideUp() / slideToggle()3个参数都一样
淡入淡出动画,常见有四个方法:fadeIn() / fadeOut() / fadeToggle() / fadeTo() ;
fadeTo([[spedd], opacoty,[easing], [fn] ])
- opacity 透明度必须写,取值0~1之间。
- speed: 三种预定速度之一的字符串(“slow”,“normal”,or “fast”)或表示动画时长的毫秒值(如: 1000),必须写
- easing: (Optional)用来指定切换效果,默认是"swing",可用参数(linear)
- fn:回调函数,在动画完成时执行的函数,每个元素执行一次。
自定义动画animate()
animate(params,[speed],[easing],[fn])
-
params:想要更改的样式属性,以对象形式传递,必须写。属性名可以不用带引号,如果是符合属性则需要取驼峰命名法。其余参数都可以省略。
• width/height
• top/bottom/left/right
• margin/padding/border-width
• font-size
• opacity
• scrollTopborderLeft。
-
speed: 三种预定速度之一的字符串(“slow”,“normal”,or “fast”)或表示动画时长的毫秒值(如: 1000),必须写
-
easing: (Optional)用来指定切换效果,默认是"swing",可用参数(linear)
-
fn:回调函数,在动画完成时执行的函数,每个元素执行一次。
<body>
<button>动起来</button>
<div></div>
<script>
$(function() {
$("button").click(function() {
$("div").animate({
left: 500,
top: 300,
opacity: .4,
width: 500
}, 500);
})
})
</script>
</body>
停止动画排队
动画或者效果一旦触发就会执行,如果多次触发,就造成多个动画或者效果排队执行。
停止动画排队的方法为:stop() ;
-
stop() 方法用于停止动画或效果。
-
stop() 写到动画或者效果的前面, 相当于停止结束上一次的动画。
总结: 每次使用动画之前,先调用 stop() ,在调用动画。
18、jQuery中的hover()和toggle()有什么区别?
-
hover(fn1,fn2): 一个模仿悬停事件(鼠标移动到一个对象上面及移出这个对象)的方法。当鼠标移动到一个匹配的元素上面时,会触发指定的第一个函数。当鼠标移出这个元素时,会触发指定的第二个函数。
//当鼠标放在表格的某行上时将class置为over,离开时置为out。 $("tr").hover(function(){ $(this).addClass("over"); }, function(){ $(this).addClass("out"); });
-
toggle(evenFn,oddFn): 每次点击时切换要调用的函数。如果点击了一个匹配的元素,则触发指定的第一个函数,当再次点击同一元素时,则触发指定的第二个函数。随后的每次点击都重复对这两个函数的轮番调用。
//每次点击时轮换添加和删除名为selected的class。 $("p").toggle(function(){ $(this).addClass("selected"); },function(){ $(this).removeClass("selected"); });
19、事件委托怎么写
事件委托就是利用事件冒泡,只指定一个事件处理程序,就可以管理某一类型的所有事件。
$(".result").on("click", ".del", function() {
$(this).addClass("deleted");
});
20、如何将form里面所有表单的value获取出来?表单序列化 serialize();
serialize() 方法通过序列化表单值,创建 URL 编码文本字符串。
您可以选择一个或多个表单元素(比如 input 及/或 文本框),或者 form 元素本身。
序列化的值可在生成 AJAX 请求时使用。
22、jQuery内容文本值
常见操作有三种:html() / text() / val() ; 分别对应JS中的 innerHTML 、innerText 和 value 属性,主要针对元素的内容还有表单的值操作。
23、jQuery 元素操作
jQuery 元素操作主要讲的是用jQuery方法,操作标签的遍历、创建、添加、删除等操作。
遍历元素
jQuery 隐式迭代是对同一类元素做了同样的操作。 如果想要给同一类元素做不同操作,就需要用到遍历。
语法1
$(“div”).each(function (index, domEle) {xxx;}
- $.each()方法遍历匹配的每一个元素。主要用DOM处理。each每一个
- 里面的回调函数有2个参数: index是每个元素的索引号,demEle是每个DOM元素对象,不是jQuery对象
- 所以要想使用jQuery方法,需要给这个dom元素转换为jQuery对象$(domEle)
$(“div”).each(object, function (index, element) {xxx;}
- $.each()方法遍历任何对象,主要用于数据处理,比如数组,对象
- 里面的函数有2个参数:index是每个元素的索引号;element遍历内容
<body>
<div>1</div>
<div>2</div>
<div>3</div>
<script>
$(function() {
// 如果针对于同一类元素做不同操作,需要用到遍历元素(类似for,但是比for强大)
var sum = 0;
var arr = ["red", "green", "blue"];
// 1. each() 方法遍历元素
$("div").each(function(i, domEle) {
// 回调函数第一个参数一定是索引号 可以自己指定索引号号名称
// console.log(i);
// 回调函数第二个参数一定是 dom 元素对象,也是自己命名
// console.log(domEle); // 使用jQuery方法需要转换 $(domEle)
$(domEle).css("color", arr[i]);
sum += parseInt($(domEle).text());
})
console.log(sum);
// 2. $.each() 方法遍历元素 主要用于遍历数据,处理数据
// $.each($("div"), function(i, ele) {
// console.log(i);
// console.log(ele);
// });
// $.each(arr, function(i, ele) {
// console.log(i);
// console.log(ele);
// })
$.each({
name: "andy",
age: 18
}, function(i, ele) {
console.log(i); // 输出的是 name age 属性名
console.log(ele); // 输出的是 andy 18 属性值
})
})
</script>
</body>
创建、添加、删除
jQuery方法操作元素的创建、添加、删除方法很多,则重点使用部分
1、创建 $(“
- ”);
2、内部添加 element.append(“内容”)
把内容放入匹配元素内部最后面,类似原生appendChild。
element.prepend(“内容”) 把内容放入匹配元素内部最前面
3、外部添加
element.after(“内容”) 把内容放入目标元素后面,
element.before(“内容”) 把内容放入目标元素前面
tip:内部添加元素,生成之后,他们是父子关系。
外部添加元素,生成之后,他们是兄弟关系。
4、删除元素
element.remove() 删除匹配的元素(本身)
element.empty() 删除匹配的元素集合中所有的子节点
element.empty(“”) 清空匹配的元素内容
tip:remove 删除元素本身
empty() 和 html(“”) 作用等价,都可以删除元素里面的内容,只不过html还可以设置内容。
24、jQuery 尺寸、位置操作
jQuery中分别为我们提供了两套快速获取和设置元素尺寸和位置的API,方便易用
jQuery 尺寸操作
jQuery 尺寸操作包括元素宽高的获取和设置,且不一样的API对应不一样的盒子模型。
语法 用法 width()/height() 取得匹配元素宽度和高度值 只算width/height innerWidth()/innerHeight() 取得匹配元素宽度和高度值 包含padding outerWidth()/outerHeight() 取得匹配元素宽度和高度值 包含padding、border outerWidth(true)/outerHeight(true) 取得匹配元素宽度和高度值 包含padding、border、margin - 以上参数为空,则是获取响应值,返回的是数字型
- 如果参数是数字,则是修改相应值
- 参数可以不必写单位
<body> <div></div> <script> $(function() { // 1. width() / height() 获取设置元素 width和height大小 console.log($("div").width()); // $("div").width(300); // 2. innerWidth() / innerHeight() 获取设置元素 width和height + padding 大小 console.log($("div").innerWidth()); // 3. outerWidth() / outerHeight() 获取设置元素 width和height + padding + border 大小 console.log($("div").outerWidth()); // 4. outerWidth(true) / outerHeight(true) 获取设置 width和height + padding + border + margin console.log($("div").outerWidth(true)); }) </script> </body>
jQuery 位置操作
jQuery的位置操作主要有三个: offset()、position()、scrollTop()/scrollLeft()
- offset()设置或获取元素偏移
- offset()方法设置或返回被选元素相对于文档的偏移坐标,跟父级没有关系。
- 该方法有2个属性,left、top。offset().top 用于获取距离文档顶部的距离,offset().left用于获取距离文档左侧的距离
- 可以设置元素的偏移:offset({top: 10,left:30});
- position()获取元素偏移
- position()方法用于返回被选元素相对于带有定位的父级偏移坐标,如果父级都没有定位,则以文档为准。
- 该方法有2个属性,left、top。position().top 用于获取距离定位父级顶部的距离,offset().left用于获取定位父级左侧的距离。
- 该方法只能获取
- scrollTop()/scrollLeft()设置或获取元素被卷去的头部和左侧
- scrollTop()方法设置或返回备选元素被卷去的头部
- 不跟参数是获取,参数为不带单位的数字则是设置被卷去头部。
<body> <div class="father"> <div class="son"></div> </div> <div class="back">返回顶部</div> <div class="container"></div> <script> $(function() { // 1. 获取设置距离文档的位置(偏移) offset console.log($(".son").offset()); console.log($(".son").offset().top); // $(".son").offset({ // top: 200, // left: 200 // }); // 2. 获取距离带有定位父级位置(偏移) position 如果没有带有定位的父级,则以文档为准 // 这个方法只能获取不能设置偏移 console.log($(".son").position()); // $(".son").position({ // top: 200, // left: 200 // }); // 3. 被卷去的头部 $(document).scrollTop(100); // 被卷去的头部 scrollTop() / 被卷去的左侧 scrollLeft() // 页面滚动事件 var boxTop = $(".container").offset().top; $(window).scroll(function() { // console.log(11); console.log($(document).scrollTop()); if ($(document).scrollTop() >= boxTop) { $(".back").fadeIn(); } else { $(".back").fadeOut(); } }); // 返回顶部 $(".back").click(function() { // $(document).scrollTop(0); $("body, html").stop().animate({ scrollTop: 0 }); // $(document).stop().animate({ // scrollTop: 0 // }); 不能是文档而是 html和body元素做动画 }) }) </script> </body>
25、jQuery拷贝对象
jQuery中分别为我们提供了深浅拷贝对象的API,方便使用
语法:
$.etend([deep],target,object1,[objectN])
- deep:如果设为true为深拷贝,默认为false 浅拷贝
- target:要拷贝的目标对象
- object1: 待拷贝到第一个对象的对象
- objectN:待拷贝到第N个对象的对象
- 浅拷贝目标对象引用的被拷贝的对象地址,修改目标对象会影响背靠背对象
- 深拷贝,前面加true,完全克隆,修改目标对象不会影响被拷贝对象。
<script> $(function() { // 1.合并数据 var targetObj = {}; var obj = { id: 1, name: "andy" }; // $.extend(target, obj); $.extend(targetObj, obj); console.log(targetObj); // 2. 会覆盖 targetObj 里面原来的数据 var targetObj = { id: 0 }; var obj = { id: 1, name: "andy" }; // $.extend(target, obj); $.extend(targetObj, obj); console.log(targetObj); }) </script>
26、jQuery事件对象
jQuery对DOM中的事件对象event进行了封装,兼容性更好,获取更方便,使用变化不大。事件被触发,就会有事件对象的产生。
element.on(eventsm,[selector],function(event) {} )
阻止默认行为: event.preventDefault() 或者 return false
阻止冒泡: event.stopPropagation()
27、jQuery事件注册
jQuery为我们提供了方便的事件注册机制,是开发人员易于操作优缺点
优点:操作简单,且不用担心事件覆盖等问题
缺点:普通的事件注册不能做事件委托,且无法实现解绑,需要借助其他方法。
语法:
element.事件(function(){})
$("div").click(function(){事件处理程序})
其他事件和原生基本一致
比如mouseover、mouseout、blur、focus、change、keydown、keyup、scroll等
<body> <div></div> <script> $(function() { // 1. 单个事件注册 $("div").click(function() { $(this).css("background", "purple"); }); $("div").mouseenter(function() { $(this).css("background", "skyblue"); }); }) </script> </body>
因为普通注册事件方法的不足,jQuery又开发了多个处理方法,重点讲解如下:
- on():用于事件绑定,目前最好用的事件绑定方法
- off():事件解绑
- trigger() / triggerHandler():事件触发
on()绑定事件
因为普通注册事件方法的不足,jQuery又创建了多个新的事件绑定方法bind() / live() / delegate() / on()等,其中最好用的是: on()
方法优势1:
可以绑定多个事件,多个处理事件处理程序
$("div").on({ mouseover: function(){}, mouseout: function(){}, click: function(){} });
如果事件处理程序相同
$("div").on("mouseover mouseout", function(){ $(this).toggleClass("current"); });
方法优势2:
可以事件委派操作。事件委派定义时,把原来加给子元素身上的事件绑定在父元素身上,就是把事件委派给父元素。
$('ul').on('click','li',function(){ alert('hello he1sen'); });
在此之前bind(),live(),delegate()等方法来处理事件绑定或者事件委派,最新版本的请用on替代他们。
方法优势3:
动态创建的元素,click()没有办法绑定事件,on() 可以给动态生成的元素绑定事件
$("div").on("click","p",function(){ alert("可以给动态生成的元素绑定事件") });
$("div").append($("<p>我是动态创建的p</p>"));
代码演示
<body> <div></div> <ul> <li>我们都是好孩子</li> <li>我们都是好孩子</li> <li>我们都是好孩子</li> </ul> <ol></ol> <script> $(function() { // (1) on可以绑定1个或者多个事件处理程序 // $("div").on({ // mouseenter: function() { // $(this).css("background", "skyblue"); // }, // click: function() { // $(this).css("background", "purple"); // } // }); $("div").on("mouseenter mouseleave", function() { $(this).toggleClass("current"); }); // (2) on可以实现事件委托(委派) // click 是绑定在ul 身上的,但是 触发的对象是 ul 里面的小li // $("ul li").click(); $("ul").on("click", "li", function() { alert(11); }); // (3) on可以给未来动态创建的元素绑定事件 $("ol").on("click", "li", function() { alert(11); }) var li = $("<li>我是后来创建的</li>"); $("ol").append(li); }) </script> </body>