库,是用于开发软件的子程序集合。库和可执行文件的区别是,库不是独立程序,他们是向其他程序提供服务的代码库链接。
JavaScript 库:即 library,是一个封装好的特定的集合(方法和函数)。就是把各种常用的代码片段,组织起来放在一个 js 文件里,组成一个包,这个包就是 JavaScript 库。
简单理解:就是一个 JS文件,里面对我们原生 js 代码进行了封装,存放到里面。这样我们就可以快速高效的使用这些封装好的功能了。
比如 jQuery,就是为了快速方便的操作 DOM,里面基本都是函数(方法)。再比如 Prototype、Dojo、Extjs 、 YUI、移动端的 zepto 等等,这些都是优秀的 JavaScript 库。它们都是对原生 JavaScript 的封装,内部都是用 JavaScript 实现的。
jQuery 是一个快速、简洁的 JavaScript 框架,是继 Prototype 之后又一个优秀的 JavaScript 代码库( 或 JavaScript 框架 )。 jQuery 设计的宗旨是 “write Less,Do More”,即倡导写更少的代码,做更多的事情。
jQuery = javascript Query(查询)。意思是查询 js,把 js 中的 DOM 操作做了封装,我们可以快速的查询使用里面的功能。
它封装 JavaScript 常用的功能代码,提供一种简便的 JavaScript 设计模式,优化 HTML 文档操作、事件处理、动画设计和 Ajax 交互。
优势:
① 官网地址:jQuery
② 版本区别:
1x:兼容IE678,使用最为广泛,官网只做BUG维护,功能不再新增。因此一般项目来说,使用1.X版本就可以了。
2x:不兼容ie678,很少有人使用,官方只做BUG维护,功能不再新增。如果不考虑兼容低版本的浏览器可以使用2.x。(过渡)
3x:不兼容ie678,只支持最新的浏览器。除非特殊要求,一般不会使用3.x版本的,很多老的jQuery插件不支持这个版本。
方式一:本地导入
直接在需要使用 jQuery 的页面引入 .js 文件:
<script src=" jQuery.js 文件路径"></script>
方式二:在线导入
我们可以通过在 script 的 src 属性中写一个网址来导入在线的 jquery 代码。
<script src="http://code.jquery.com/jquery-latest.js"></script>
$(document).ready(function (){
alert("hello jquery");
})
jQuery(document).ready(function () {
alert("hello jquery");
})
// 简化方式,推荐
$(function () {
alert("hi jquery");
})
jQuery(function () {
alert("hi jquery");
})
$
是 jQuery 的别称,在代码中可以使用 jQuery 代替$
,但为了方便,通常都使用$
。
冲突——多库共存
原因:随着jQuery的流行,采用jQuery和$
符为命名空间的 js 库越来越多,当然 jQuery 的$
符也是参照的 Prototype库的,所以当多个库同时以$
符或者 jQuery 为命名空间时,那么此时,就会产生冲突。
解决方法:
jQuery.noConflict();
//1.释放操作在其他函数之前
//2.释放后不能用dollar符
var suiBian = jQuery.noConflict();
//此时suiBian为新的访问符号
DOM 对象:用原生 js 获取过来的对象就是 DOM 对象。
jQuery 对象:用 jQuery 方式获取过来的对象就是 jQuery 对象。本质:通过 $ 把 DOM 元素进行了封装(伪数组形式存储)。
区别:jQuery 对象只能使用 jQuery 方法,反之亦然。
相互转换:
$('DOM对象');
$('DOM对象')[index]; // index 是索引号
$('DOM对象').get(index);
jQuery选择器虽然很多,但是选择器之间可以相互替代,就是说获取一个元素,你会有很多种方法获取到。所以我们平时真正能用到的只是少数的最常用的选择器。
$(“选择器”) // 选择器格式与 css 选择器格式一摸一样
名称 | 用法 | 描述 |
---|---|---|
ID选择器 | $("#id"); | 获取指定 ID 的元素 |
类选择器 | $(".class"); | 获取同一类 class 的元素 |
标签选择器 | $(“div”); | 获取同一类标签的所有元素 |
并集选择器 | $(“div,li,p”); | 使用逗号分隔,获取多个元素 |
交集选择器 | $(“div.show”); | 获取 class 为 show 的 div 元素 |
全选选择器 | $("*"); | 匹配所有元素 |
名称 | 用法 | 描述 |
---|---|---|
子代选择器 | $(“ul>li”); | 使用 > 号,获取儿子层级的元素;注意,并不会获取孙子层级的元素 |
后代选择器 | $(“ul li”); | 使用空格,代表后代选择器,获取 ul 下的所有 li 元素,包括孙子等 |
名称 | 用法 | 描述 |
---|---|---|
:eq(index) | $(“li:eq(1)”); | 获取到的li元素中,选择索引号为1的元素,索引号index从0开始。 |
:odd | $(“li:odd”); | 获取到的li元素中,选择索引号为奇数的元素 |
:even | $(“li:even”); | 获取到的li元素中,选择索引号为偶数的元素 |
筛选选择器的功能与过滤选择器有点类似,但是用法不一样,筛选选择器主要是方法。
名称 | 用法 | 描述 |
---|---|---|
parent() | $(".first").parent(); | 查找父亲 |
children(selector) | $(“ul”).children(“li”) | 相当于$(“ul>li”),子类选择器 |
find(selector) | $(“ul”).find(“li”); | 相当于$(“ul li”),后代选择器 |
siblings(selector) | $(".first").siblings(“li”); | 查找兄弟节点,不包括自己本身。 |
next() | $(".first").next(); | 查找当前元素之后的下一个兄弟 |
nextAll() | $(".first").nextAll(); | 查找当前元素之后的所有同辈元素 |
prev() | $(".last").prev(); | 查找当前元素之前的上一个兄弟 |
prevAll() | $(“last”).prevAll(); | 查找当前元素之前的所有同辈元素 |
hasClass(class) | $(“div”).hasClass(“show”) | 检查当前的元素是否含有某个特定的类,如果有,则返回 true |
eq(index) | $(“li”).eq(2); | 相当于$(“li:eq(2)”),index 从0开始 |
$(function() {
$("button").click(function(){
$(this).css(); // 对自己设置变化
$(this).siblings("button").css(); // 给其他兄弟去掉变化
})
})
$(function() {
$("button").click(function(){
$(this).css().siblings("button").css(); // 对自己设置变化,给其他兄弟去掉变化
})
})
遍历 jQuery 对象内部 DOM 元素(伪数组形式存储)的过程就叫隐式迭代
简单理解:给匹配的所有元素进行循环遍历,执行相应的方法,而不是我们再进行循环,简化我们的操作,方便我们的调用。
// 给四个div设置背景颜色为粉色 jquery对象不能使用style
$("div").css("background", "pink");
// 隐式迭代就是把匹配的所有元素内部进行遍历循环,给每一个元素添加css这个方法
$("ul li").css("color", "red");
jQuery 可以使用 css 方法来修改简单元素样式;也可以操作类,修改多个样式。
$(this).css("color");
$(this).css("color","red");
$(this).css({"color":"red","font-size":"20px"});
作用等同于以前的 classList,可以操作类样式,注意操作类里面的参数不要加点
$("div").addClass("current");
$("div").removeClass("current");
$("div").toggleClass("current");
// js 中的 className 会覆盖元素原先里面的类名
var one = document.querySelector(".one");
one.className = "two"; // one : class="two"
// jQuery 里面的类操作只是对指定类进行操作,不影响原先的类名
$(".one").addClass("two"); // one: class="one two"
① 显示效果
show([speed,[easing],[fn]])
概述
显示隐藏的匹配元素。
这个就是 ‘show( speed, [callback] )’ 无动画的版本。如果选择的元素是可见的,这个方法将不会改变任何东西。无论这个元素是通过hide()方法隐藏的还是在CSS里设置了display:none;,这个方法都将有效。
显示参数
speed
:三种预定速度之一的字符串(“slow”,“normal”, or “fast”)或表示动画时长的毫秒数值(如:1000)。easing
:(Optional) 用来指定切换效果,默认是"swing",可用参数"linear"。fn
:在动画完成时执行的函数,每个元素执行一次。② 隐藏效果
hide([speed,[easing],[fn]])
概述
隐藏显示的元素。
这个就是 ‘hide( speed, [callback] )’ 的无动画版。如果选择的元素是隐藏的,这个方法将不会改变任何东西。
显示参数
speed
:三种预定速度之一的字符串(“slow”,“normal”, or “fast”)或表示动画时长的毫秒数值(如:1000)。easing
:(Optional) 用来指定切换效果,默认是"swing",可用参数"linear"。fn
:在动画完成时执行的函数,每个元素执行一次。① 下滑效果
slideDown([speed],[easing],[fn])
概述
显示参数
参数都可以省略。
speed
:三种预定速度之一的字符串(“slow”,“normal”, or “fast”)或表示动画时长的毫秒数值(如:1000)。
easing
:(Optional) 用来指定切换效果,默认是"swing",可用参数"linear"。
fn
:在动画完成时执行的函数,每个元素执行一次。
② 上滑效果
slideUp([speed,[easing],[fn]])
概述
显示参数
参数都可以省略。
speed
:三种预定速度之一的字符串(“slow”,“normal”, or “fast”)或表示动画时长的毫秒数值(如:1000)。
easing
:(Optional) 用来指定切换效果,默认是"swing",可用参数"linear"。
fn
:在动画完成时执行的函数,每个元素执行一次。
③ 滑动效果
slideToggle([speed],[easing],[fn])
概述
显示参数
参数都可以省略。
speed
:三种预定速度之一的字符串(“slow”,“normal”, or “fast”)或表示动画时长的毫秒数值(如:1000)。
easing
:(Optional) 用来指定切换效果,默认是"swing",可用参数"linear"。
fn
:在动画完成时执行的函数,每个元素执行一次。
hover([over,]out)
概述
显示参数
over
:鼠标移到元素上要触发的函数(相当于 mouseenter)。
out
:鼠标移出元素要触发的函数(相当于 mouseenter)。
① 动画或效果队列
动画或者效果一旦触发就会执行,如果多次触发,就造成多个动画或者效果排队执行。
② 停止排队
stop([clearQueue],[jumpToEnd])
概述
显示参数
queue
:用来停止动画的队列名称。
clearQueue
:如果设置成true,则清空队列。可以立即结束动画。
jumpToEnd
:如果设置成true,则完成队列。可以立即完成动画。
注意:stop() 写到动画或者效果的前面,相当于停止结束上一次的动画。
① 淡入效果
fadeIn([speed],[easing],[fn])
概述
显示参数
参数都可以省略
speed
:三种预定速度之一的字符串(“slow”,“normal”, or “fast”)或表示动画时长的毫秒数值(如:1000)。
easing
:(Optional) 用来指定切换效果,默认是"swing",可用参数"linear"。
fn
:在动画完成时执行的函数,每个元素执行一次。
② 淡出效果
fadeOut([speed],[easing],[fn])
概述
显示参数
speed
:三种预定速度之一的字符串(“slow”,“normal”, or “fast”)或表示动画时长的毫秒数值(如:1000)。easing
:(Optional) 用来指定切换效果,默认是"swing",可用参数"linear"。fn
:在动画完成时执行的函数,每个元素执行一次。③ 淡入淡出切换效果
fadeToggle([speed,[easing],[fn]])
概述
显示参数
speed
:三种预定速度之一的字符串(“slow”,“normal”, or “fast”)或表示动画时长的毫秒数值(如:1000)。easing
:(Optional) 用来指定切换效果,默认是"swing",可用参数"linear"。fn
:在动画完成时执行的函数,每个元素执行一次。④ 渐进方式调整到指定的不透明度
fadeTo([[speed],opacity,[easing],[fn]])
概述
显示参数
speed
:三种预定速度之一的字符串(“slow”,“normal”, or “fast”)或表示动画时长的毫秒数值(如:1000)。opacity
:一个0至1之间表示透明度的数字。easing
:(Optional) 用来指定切换效果,默认是"swing",可用参数"linear"。fn
:在动画完成时执行的函数,每个元素执行一次。animate(params,[speed],[easing],[fn])
概述
显示参数
params
:一组包含作为动画属性和终值的样式属性和及其值的集合(用对象实现),必须写。speed
:三种预定速度之一的字符串(“slow”,“normal”, or “fast”)或表示动画时长的毫秒数值(如:1000)。easing
:(Optional) 用来指定切换效果,默认是"swing",可用参数"linear"。fn
:在动画完成时执行的函数,每个元素执行一次。所谓元素固有属性就是元素本身自带的属性,如元素里面的
herf
,元素里面的
type
。
① 获取属性语法
prop("属性")
② 设置属性语法
prop("属性","属性值")
自定义属性就是用户自己给元素添加的属性。比如给li
添加index="1"
。
① 获取属性语法
attr("属性")
② 设置属性语法
attr("属性","属性值")
该方法也可用于获取 H5 自定义属性。
data()方法可以在指定的元素上存取数据,并不会修改DOM 的元素结构,一旦页面刷新,之前存放的数据都将被移除。
① 附加数据语法
data("key","value") // 向被选元素附加数据
② 获取数据语法
data("key") // 从被选元素获取数据
如果浏览器支持 HTML5,同样可以读取该 DOM 中使用 data-[key] = [value] 所存储的值。
相当于原生 js 中的 innerHTML
html() // 获取元素的内容
html("内容") // 设置元素的内容
相当于原生 js 中的 innerText
text() // 获取元素的内容
text("内容") // 设置元素的内容
相当于原生 js 中的 value
val() // 获取元素的内容
val("内容") // 设置元素的内容
隐式迭代:对同一类元素做相同操作。如果做不同操作,需要使用遍历:
$("div").each(function (index, domEle) {xxx;})
// 也可以写成
$.each($("div"),function (index, domEle) {xxx;}))
// 主要用于处理数据
index 是每个元素的索引号,domEle 是每个 DOM 元素对象,不是 jQuery 对象
想要使用 jQuery 方法,就要给这个 dom 元素转换为 jQuery 对象 $(domEle)
① 内部添加
$("ul").append(li);//放到最后面,类似原生 appendChild
② 外部添加
el.before(内容); // 把内容放到目标元素前面
el.after(内容); // 把内容放到目标元素后面
内部添加元素后是父子关系
外部添加元素后是兄弟关系
3.6.3 删除元素
el.remove() // 删除匹配节点(本身)
el.empty() // 删除匹配节点的子节点
el.html("") // 相当于 empty()
语法 | 用法 |
---|---|
width()/height() | 取得匹配元素宽度和高度值,只算width/height |
innerWidth()/innerHeight() | 取得匹配元素宽度和高度值,包括padding |
outerWidth()/outerHeight() | 取得匹配元素宽度和高度值,包括padding和border |
outerWidth(true)/outerHeight(true) | 取得匹配元素宽度和高度值,包括padding、border和margin |
- 以上参数为空,则获取响应值,返回的是数字型
- 如果参数未数字,则是修改相应值
- 参数可以不写单位
① offset() 设置或获取元素偏移
② position() 获取元素偏移
该方法只能获取不能设置偏移
③ scrollTop()/scrollLeft() 设置或获取元素被卷去的头部或左侧
单个事件注册
element.事件(function);
$("div").click(function(){ 事件处理程序 }) // 其他事件和原生事件基本一致
on(events,[selector],[data],fn)
概述
在选择元素上绑定一个或多个事件的事件处理函数。
on() 方法绑定事件处理程序到当前选定的 jQuery 对象中的元素。
显示参数
events
:一个或多个用空格分隔的事件类型和可选的命名空间,如"click"或"keydown.myPlugin" 。
selector
:一个选择器字符串用于过滤器的触发事件的选择器元素的后代。如果选择的< null或省略,当它到达选定的元素,事件总是触发。
data
:当一个事件被触发时要传递event.data给事件处理函数。
fn
:该事件被触发时执行的函数。 false 值也可以做一个函数的简写,返回false。
优势1
// 同一对象不同操作不同回调
$("div").on({
mouseenter:function() {
$(this).css("color", "red");
},
mouseleave:function() {
$(this).css("color", "black");
}
})
// 同一对象不同操作相同回调
$("div").on("mouseenter mouseleave", function(){
$(this).toggleClass("current");
})
可以事件委派操作。事件委派的定义是:把原来子元素身上的事件绑定到父元素上,就是把事件委派给父元素。
$("ul").on("click", "li", function(){
alert("clicked li");
});
动态创建的元素,click() 没有办法绑定事件,on() 可以给动态生成元素绑定事件。
$("ul").on("click", "li", function(){
alert("clicked li");
});
let li = $("click ");
$("ul").append(li);
off(events,[selector],[fn])
概述
在选择元素上移除一个或多个事件的事件处理函数。
off() 方法移除用 on() 绑定的事件处理程序。
显示参数
events
:一个或多个空格分隔的事件类型和可选的命名空间,或仅仅是命名空间,比如"click", “keydown.myPlugin”, 或者 “.myPlugin”。
selector
:一个最初传递到 .on() 事件处理程序附加的选择器。
fn
:事件处理程序函数以前附加事件上,或特殊值 false。
示例
off(); // 解除所有事件
off("click"); // 只解除点击事件
off("click", "li"); // 解除事件委托
one(type,[data],fn)
概述
显示参数
type
:添加到元素的一个或多个事件。由空格分隔多个事件。必须是有效的事件。
data
:将要传递给事件处理函数的数据映射。
fn
:每当事件触发时执行的函数。
有些事件希望自动触发,比如轮播图自动播放功能与点击右侧按钮功能一致,可以利用定时器自动触发右侧按钮点击事件,不必鼠标点击触发。
el.click(); // 简写形式
el.trigger("type"); // 自动触发形式
el.triggerHandler("type"); // 自动触发形式,不会触发元素的默认行为
事件被触发,就会有事件对象的产生。
on(events,[selector],function(even) { })
even.preventDefault() // 阻止默认行为 或者用 return false
even.stopPropagation() // 阻止冒泡