- A+
一、jQuery介绍
1、jQuery是一个轻量级的、兼容多浏览器的JavaScript库。
2、jQuery使用户能够更方便地处理HTML Document、Events、实现动画效果、方便地进行Ajax交互,能够极大地简化JavaScript编程。它的宗旨就是:“Write less, do more.“
jQuery引入
首先需要jQuery官网下载jQuery的文件,然后在HTML文件中引入这个文件,就可以使用这个文件中帮我们提供的jquery的接口了。
<script src="jQuery.js"></script>
二、jQuery对象和DOM对象
jQuery 找到的标签对象称为 ——> jQuery对象
原生 JS 找到的标签对象称为 ——> DOM对象
DOM对象只能使用DOM对象的方法,不能使用jQuery对象的方法
jQuery对象也是,它不能使用DOM对象的方法
我们在声明一个jQuery对象变量的时候在变量名前面加上$:
var $variable = jQuery对像; var variable = DOM对象;
jQuery对象转成DOM对象,通过一个jQuery对象+[0]索引零,就变成了DOM对象,就可以使用JS的代码方法了,DOM对象转换成jQuery对象:$(DOM对象),通过$符号包裹一下就可以了
$variable[0];
DOM 对象和 jQuery 对象互相转换:
jQuery对象转DOM对象 ——> jQuery对象[0] 示例:$('#d1')[0] DOM对象转jQuery对象 ——> $(dom对象)
三、jQuery选择器
不管找什么标签,用什么选择器,都必须要写$(""),引号里面再写选择器,通过jQuery找到的标签对象就是一个jQuery对象,用原生JS找到的标签对象叫做DOM对象
选择器找到的可能是多个标签,会放到数组里面,但还是jquery对象,能够直接使用jquery的方法,意思是找到的所有标签进行统一设置,如果要单独设置选中的所有标签中的某个标签,可以通过索引取值的方式找到,然后注意,通过索引取值拿到的标签,是个dom对象
基本选择器
和css一样
id选择器: $("#id"); 标签选择器: $("tagName"); class选择器: $(".className"); 配合使用: $("div.c1"); // 找到有c1 class类的div标签 所有元素选择器: $("*"); 组合选择器: $("#id, .className, tagName");
层级选择器
和css一样
x 和 y 可以为任意选择器
$("x y"); // x 的所有后代 y(子子孙孙) $("x > y"); // x 的所有儿子 y(儿子) $("x + y"); // 找到所有紧挨在 x 后面的 y $("x ~ y"); // x 之后所有的兄弟 y
基本筛选器
选择之后进行过滤筛选
方式一:
:first // 第一个 :last // 最后一个 :eq(index) // 索引等于index的那个元素 :even // 匹配所有索引值为偶数的元素,从 0 开始计数 :odd // 匹配所有索引值为奇数的元素,从 0 开始计数 :gt(index) // 匹配所有大于给定索引值的元素 :lt(index) // 匹配所有小于给定索引值的元素 :not(元素选择器) // 移除所有满足not条件的标签 :has(元素选择器) // 选取所有包含一个或多个标签在其内的标签(指的是从后代元素找) // 找到所有后代中有h1标签的div标签,意思是首先找到所有div标签,把这些div标签的后代中有h1的div标签筛选出来 $("div:has(h1)") // 找到所有后代中有c1样式类(类属性class='c1')的div标签 $("div:has(.c1)") $("li:not(.c1)") // 找到所有不包含c1样式类的li标签 $("li:not(:has(a))") // 找到所有后代中不含a标签的li标签 例子: <ul> <li id="1">上海</li> <li id="2">成都</li> <li id="3">泸州</li> <li id="4">雅安</li> <li id="5">北京</li> </ul> $('li:first'); // 查找所有li标签中的第一个标签
方式二:
和前面使用冒号的一样 :first等,只不过冒号的那个是写在选择器里面的,而下面的这几个是方法
.first() // 获取匹配的第一个元素 .last() // 获取匹配的最后一个元素 .not() // 从匹配元素的集合中删除与指定表达式匹配的元素 .has() // 保留包含特定后代的元素,去掉那些不含有指定后代的元素。 .eq() // 索引值等于指定值的元素 $('li').first(); // 查找所有li标签中的第一个标签
属性选择器
[attribute] [attribute=value] // 属性等于 [attribute!=value] // 属性不等于 例子:多用于input标签 <input type="text"> <input type="password"> <input type="checkbox"> $("input[type='checkbox']"); // 取到checkbox类型的input标签 $("input[type!='text']"); // 取到类型不是text的input标签
表单筛选器
多用于找form表单里面出现的input标签
找到的是type属性为这个值的input标签中
:text :password :file :radio :checkbox :submit :reset :button 例子:多用于input标签 <input type="text"> <input type="password"> <input type="checkbox"> $(':password') // 找到input标签中type属性为password的标签
表单对象属性筛选器
:enabled // 可用的标签 :disabled // 不可用的标签 :checked // 选中的input标签 :selected // 选中的option标签 例子1: <input type="text" disabled="disabled"> <input type="password"> $("input:enabled") // 找到可用的input标签 例子2: <select id="s1"> <option value="1">北京</option> <option value="2">四川</option> <option selected value="3">云南</option> // 默认选中 <option value="4">深圳</option> </select> $(":selected") // 找到所有被选中的option
筛选器方法
选择器或者筛选器选择出来的都是对象,而筛选器方法其实就是通过对象来调用一个进一步过滤作用的方法,写在对象后面加括号,不再是写在选择器里面的了。
下一个:
$('#l3').next(); // 找到下一个兄弟标签 $('#l3').nextAll(); // 找到下面所有的兄弟标签 $('#l3').nextUntil('#l5'); // 往下直到找到id为l5的标签,不包含它
上一个:
$("#id").prev() // 找到上一个兄弟标签 $("#id").prevAll() // 找到上面所有的兄弟标签 $("#id").prevUntil("#i2") // 往上直到找到id为i2的标签,不包含它
父亲元素:
$("#id").parent() // 查找当前元素的父亲元素 $("#id").parents() // 查找当前元素的所有的父辈元素(爷爷辈、祖先辈都找到) $("#id").parentsUntil('body') // 查找当前元素的所有的父辈元素,直到遇到匹配的那个元素为止,这里直到body标签,不包含body标签,基本选择器都可以放到这里面使用。
儿子和兄弟元素:
$('ul').children(); // 找到当前标签的所有儿子标签 $('ul').children('#l3'); // 找到符合后面这个选择器的儿子标签 $('#l5').siblings(); // 找到兄弟们,不包含自己 $('#l5').siblings('#l3'); // 找到符合后面这个选择器的兄弟标签
查找:find
搜索所有与指定表达式匹配的元素。这个函数是找出正在处理的元素的后代元素的好方法。
$('ul').find('#l3'); --> 类似于 $('ul #l3')
过滤:filter
和find不同,find是找div标签的子子孙孙中找到一个符合条件的标签
// 从结果集中过滤出有c1样式类的,从所有的div标签中过滤出有class='c1'属性的div ('li').filter('.l3');
四、标签操作
样式操作
样式类操作:
addClass(); // 添加指定的CSS类名。 removeClass(); // 移除指定的CSS类名。 hasClass(); // 判断样式存不存在 toggleClass(); // 切换CSS类名,如果有就移除,如果没有就添加。
例子:
$('div.c1').addClass('c2'); $('div.c1').removeClass('c2'); $('div.c1').hasClass('c2'); $('div.c1').toggleClass('c2');
CSS样式:
// 原生js 标签.style.backgroundColor = 'black'; // jQuery $('.c1').css('background-color','red'); // 同时设置多个css样式 $('.c1').css({'background-color':'yellow','width':'200px'})
位置操作:
.offset()
方法允许我们检索一个元素相对于文档(document)的当前位置。
.position()
的差别在于: .position()
获取相对于它最近的具有相对位置(position: relative 或 position: absolute)
的父级元素的距离,如果找不到这样的元素,则返回相对于浏览器界面左上角的距离。
offset() // 获取匹配元素在当前窗口的相对偏移或设置元素位置 position() // 获取匹配元素相对父元素的偏移,不能设置位置 $(window).scrollTop(); // 滚轮向下移动的距离 $(window).scrollLeft(); // 滚轮向左移动的距离 // 查看位置 $('.c2').position(); // 查看相对于父级元素位置 $('.c2').offset(); // 查看距离窗口左上角的绝对位置 // 设置位置 $('.c2').offset({'top':'20','left':'40'});
尺寸操作:
// 与盒子模型相关 $('.c1').height(); // content 高度 $('.c1').width(); // content 宽度 $('.c1').innerHeight(); // content 高度 + padding高度 $('.c1').innerWidth(); // content 宽度 + padding宽度 $('.c1').outerHeight(); // content 高度 + padding高度 + border高度 $('.c1').outerWidth(); // content 宽度 + padding宽度 + border宽度
文本操作
HTML:
html() // 取得第一个匹配元素的html内容,包含标签内容 html(val) // 修改所有匹配元素的html内容,识别标签,能够表现出标签的效果
文本值:
text() // 取得所有匹配元素的内容,只有文本内容,没有标签 text(val) // 修改所有匹配元素的内容,不识别标签,将标签作为文本插入进去
例子:
$('.c1').text('<h3>hello Word</h3>'); $('.c1').html('<h3>hello Word</h3>');
值操作
val() // 取得第一个匹配元素的当前值 val(val) // 修改所有匹配元素的值 val([val1, val2]) // 修改多选的checkbox、多选select的值
实例一:获取值
<input type="text" class="c1"> ————>获取值:$('.c1').val(); <input type="checkbox" value="1"> // 获取被选中的值这样是不行的:$(':checkbox:checked').val(); // 需要循环取值 var d = $(':checkbox:checked'); for (var i=0;i<d.length;i++){ console.log(d.eq(i).val()); } 单选select ---> $('#city').val(); 多选select ---> $('#author').val(); // ["2", "3"]
实例二:设置值
<input type="text" class="c1"> ——>设置值:$('.c1').val('小杨'); <input type="checkbox" value="1"> ——>设置值:$(':checkbox').val([1,3]); // 如果直接:$(':checkbox').val(1);这样的话会把所有的的value全部设置为1 单选select ---> $('#city').val('1'); // 或者——> option value='1' 多选select ---> $('#author').val(['2','3']);
属性操作
用于ID自带属性等或自定义属性:
attr(attrName) // 返回第一个匹配元素的属性值 attr(attrName, attrValue) // 为所有匹配元素设置一个属性值 attr({k1: v1, k2:v2}) // 为所有匹配元素设置多个属性值 removeAttr(attrName) // 从每一个匹配的元素中删除一个属性
用于checkbox和radio
prop() // 获取属性
实例:
// 设置单个属性 $('.c1').attr('id','d1'); // 设置多个属性 $('.c1').attr({name:'xiao',id:'d1'}); // 查看属性 $('.c1').attr('属性名'); // 删除属性 $('.c1').removeAttr('属性名'); // prop ——> 针对的是checkedselecteddisabled // 查看标签是否有checked属性,也就是是否被选中 attr ————> $(':checked').attr('checked'); // 返回:选中(checked),没选中(undefined) prop ————> $(':checked').prop('checked'); // 返回:选中(true),没选中(false) // 通过设置属性的方式来设置是否选中: $(':radio').eq(2).prop('checked',true); // true和false不能加引号 $(':radio').eq(2).prop('checked',false);
prop和attr的区别:
attr全称attribute(属性)
prop全称property(属性)
虽然都是属性,但他们所指的属性并不相同,attr所指的属性是HTML标签属性,而prop所指的是DOM对象属性,可以认为attr是显式的,而prop是隐式的。
简单总结:
1、对于标签上有的能看到的属性和自定义属性都用attr
2、对于返回布尔值的比如checkbox、radio和option的是否被选中或者设置其被选中与取消选中都用prop。
具有 true 和 false 两个属性的属性,如 checked, selected 或者 disabled 使用prop(),其他的使用 attr()
文档操作
添加到指定元素--内部的后面
$(A).append(B) // 把B追加到A $(A).appendTo(B) // 把A追加到B 实例: // 添加字符串照样能识别标签 $('#d1').append('<a href="http://www.jd.com">京东</a>');
添加到指定元素--内部的前面
$(A).prepend(B) // 把B前置到A $(A).prependTo(B) // 把A前置到B 实例: // 添加字符串照样能识别标签 $('#d1').perpend('<a href="http://www.jd.com">京东</a>');
添加到指定元素--外部的后面
$(A).after(B) // 把B放到A的后面 $(A).insertAfter(B) // 把A放到B的后面 实例: // 添加字符串照样能识别标签 $('#d1').after('<a href="http://www.jd.com">京东</a>');
添加到指定元素--外部的前面
$(A).before(B) // 把B放到A的前面 $(A).insertBefore(B) // 把A放到B的前面
移除和清空元素
remove() // 从DOM中删除所有匹配的元素。 empty() // 删除匹配的元素集合中所有的子节点,包括文本被全部删除,但是匹配的元素还在 实例: $('div').remove(); // 移除div标签 $('div').empty(); // 清空div标签中的所有内容
替换
replaceWith() replaceAll() 实例: var a = document.createElement('a') a.href = 'http://www.baidu.com'; a.innerText = '百度'; // 写法不一样效果一样 $('div').replaceWith(a); // 将所有的div标签替换成a标签 $(a).replaceAll('div'); // 将所有的div标签替换成a标签
克隆
clone() // 克隆 实例: <button class="btn">按钮</button> <script> $('.btn').click(function (){ // var a = $(this).clone(); // 克隆标签 var a = $(this).clone(true); // 连带事件一起克隆 $(this).after(a) }) </script>
五、事件
事件绑定方式
方式一:
<style> .c1{ height: 100px; width: 100px; background: red; } </style> <div class="c1"></div> <script> $('.c1').click(function () { $(this).css({backgroundColor:'green'}) }) </script>
方式二:
<style> .c1{ height: 100px; width: 100px; background: red; } </style> <div class="c1"></div> <script> $('.c1').on('click', function () { $(this).css({backgroundColor:'green'}) }) </script>
常用事件
click(function(){...}) // 左键点击的事件 hover(function(){...}) // 鼠标悬浮触发的事件 blur(function(){...}) // 失去光标(焦点)触发的事件 focus(function(){...}) // 获取光标触发的事件 change(function(){...}) // 内容发生变化,input,select等 keyup(function(){...}) // 键盘抬起触发的事件 keydown(function(){...}) // 键盘按下触发的事件
**左键点击的事件:click **
$('.c1').click(function () { $(this).css({backgroundColor:'green'}) })
获取光标触发的事件:focus —— 失去光标(焦点)触发的事件:blur
<style> .c1{ height: 100px; width: 100px; background: red; } </style> <div class="c1" ></div> <input type="text"> <script> $('[type="text"]').focus(function () { // 获取光标事件 $('.c1').css({backgroundColor:'green'}) }) $('[type="text"]').blur(function () { // 失去光标事件 $('.c1').css({backgroundColor:'red'}) }) </script>
域内容发生改变时触发的事件:change ——内容发生变化,input,select等
<select name="" id="d1"> <option value="1">成都</option> <option value="2">北京</option> <option value="3">上海</option> </select> <script> $('#d1').change(function () { console.log($(this).val()) }) </script>
input 实时监听事件:只要input框里面的值发生变化就触发某个事件,input事件不能直接绑定,必须用on绑定才行
<input type="text" id="d1"> <script> $('#d1').on("input", function () { console.log($(this).val()) }) </script>
鼠标悬浮触发的事件:hover
<style> .c1{ height: 100px; width: 100px; background: red; } </style> <div class="c1"></div> <script> $('.c1').hover( // 第一步:鼠标放上去 function () {$(this).css({backgroundColor: 'yellow'});}, // 第二步:鼠标移走 function () {$(this).css({backgroundColor: 'red'});} ) </script>
鼠标悬浮触发的事件:mouseenter、mouseout——等同于hover
mouseover 和 mouseenter 的区别是:mouseover事件是如果该标签有子标签,那么移动到该标签或者移动到子标签时会连续触发,mmouseenter事件不管有没有子标签都只触发一次,表示鼠标进入这个对象
<style> .c1{ height: 100px; width: 100px; background: red; } </style> <div class="c1"></div> <script> // 第一步:鼠标放上去 $('.c1').mouseenter(function () { $(this).css({backgroundColor: 'yellow'}) }) // 第二部:鼠标移走 $('.c1').mouseout(function () { $(this).css({backgroundColor: 'red'}) }) </script>
键盘按下触发的事件:keydown
$(window).keydown(function (e) { console.log(e.keyCode); //每个键都有一个keyCode值,通过不同的值来触发不同的事件 })
键盘抬起触发的事件:keyup
$(window).keyup(function (e) { console.log(e.keyCode); })
移除事件:. off
.off( events [, selector ][,function(){}]) 1.events: 事件 2.selector: 选择器(可选的) 3.function: 事件处理函数 off() 方法移除用 .on()绑定的事件处理程序。 $("li").off("click");就可以了
事件冒泡
冒泡的意思就是因为HTML可以嵌套,如果你给儿子标签绑定了事件或者没有绑定点击事件,父级标签绑定了点击事件,那么你一点击子标签,不管子标签有没有绑定事件,都会触发父级标签的点击事件,如果有,会先触发子标签的点击事件,然后触发父级标签的点击事件,不管子标签有没有点击事件,都会一级一级的往上找点击事件
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <style> #d1{ background-color: red; height: 200px; } #d2{ background-color: green; height: 100px; width: 100px; } </style> </head> <body> <div id="d1"> <div id="d2"></div> </div> <script src="jquery.js"></script> <script> $('#d1').click(function () { alert('父级标签'); }); $('#d2').click(function () { alert('子级标签'); }); </script> </body> </html>
阻止事件冒泡
就是为了阻止后续事件发生
1、return false;
$('#d1').click(function () { alert('父级标签'); }); $('#d2').click(function () { alert('子级标签'); return false });
2、e.stopPropagation( );
用事件对象的这个方法就能阻止冒泡 (Propagation:传递的意思)
$('#d1').click(function () { alert('父级标签'); }); $('#d2').click(function (e) { // 这个参数e(只是个形参)表示当前事件本身,这个事件也是一个对象 alert('子级标签'); e.stopPropagation(); });
事件委托
事件委托是通过事件冒泡的原理,利用父标签去捕获子标签的事件,给未来将要添加进来的某些子标签自动绑定上事件。
例一:没有事件委托,只有第一个按钮可以触发事件,其他新添加的按钮虽然 class=c1 但是不能触发事件
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <div class="cc"> <button class="c1">添加按钮</button> </div> <script src="jQuery.js"></script> <script> $('.c1').click(function () { var btn = document.createElement("button"); // 新建button标签 btn.innerText = '添加按钮'; btn.className = 'c1' // 给新标签添加class=c1 $(this).after(btn); // 把新标签放在自己的后面 }) </script> </body> </html>
列二:设置事件委托,每个新增按钮都可以触发事件
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <div class="cc"> <button class="c1">添加按钮</button> </div> <script src="jQuery.js"></script> <script> // 将 'button.c1' 选择器中的标签的点击事件委托给了 $('div.cc') $('div.cc').on('click','button.c1',function () { var btn = document.createElement("button"); btn.innerText = '添加按钮'; btn.className = 'c1' $(this).after(btn); }) </script> </body> </html>
六、补充
页面载入
JS 代码写到head标签和写道 body 标签下面的作用是不同的,写在 head 标签里面的话,如果你写了操作某个标签的内容的话,那个标签还没加载出来,先加载了你的 JS 代码,就找不到这个标签,所以不会生效,所以写在 body 标签最下面是一种解决办法,但还有另外两种方法:
方法一 :等页面上所有的元素都加载完,在执行这里面的 JS 代码
缺点:如果你自己写了两个 JS 文件,每个 JS 文件中都有一个 window.onload 的话,那么后引入的文件会把前面引入的文件的 window.onload 里面的 JS 代码全部覆盖掉,也会等到页面上的文档、图片、视频等所有资源都加载完才执行里面的 JS 代码,加载比较慢
window.onload=function(){ // JS的代码 }
方法二(推荐):不存在覆盖问题,而且只要文档加载完就触发,不需要等着一些图片视频什么的,加载 JS 效果的速度快。
// 写法一: $(document).ready(function(){ // JS的代码 }) // 写法二:简写 $(function(){ // JS代码 })
$(document).ready 与 window.onload( ) 的区别
1、window.onload() 函数有覆盖现象,必须等待着图片资源加载完成之后才能调用
2、$(document).ready 的这个入口函数没有函数覆盖现象,文档加载完成之后就可以调用(建议使用此函数)
动画效果
基本动画
show() --> $('.c1').show(5000) // 5秒之后显示这个标签,显示过程有个动画 hide() --> $('.c1').hide(5000) // 5秒之后这个标签消失,消失过程有个动画
滑动(拉窗帘一样)
slideDown() --> $('.c1').slideDown(5000) slideUp() --> $('.c1').slideUp(5000) slideToggle() --> $('.c1').slideToggle(5000) // 前两个互相切换
淡入淡出(控制透明度)
fadeIn() -->$('.c1').fadeIn(5000) fadeOut() -->$('.c1').fadeOut(5000) fadeTo() -->$('.c1').fadeTo(5000,0.2) // 0.2是最后显示透明度 fadeToggle() -->$('.c1').fadeToggle(5000) // 前两项互相切换
each 循环
$.each (可迭代对象,function (k,v) { 迭代结果操作 } )
function 里面可以接受两个参数,K 是索引,V 是每次循环的具体元素。
实例一:获取选中的值 <input type="checkbox" value="1">一 <input type="checkbox" value="2">二 <input type="checkbox" value="3">三 <input type="checkbox" value="4">四 <input type="checkbox" value="5">五 $.each($(':checkbox:checked'),function(k,v){ console.log(k,v.value); }) // 输出 0 "2" 1 "4" 2 "5" 实例二: var li =[10,20,30,40] $.each(li,function(k, v){ console.log(k, v); }) // 输出 0 10 1 20 2 30 3 40
.each ( function (k,v) { 迭代结果操作 } )
描述:遍历一个jQuery对象,为每个匹配元素执行一个函数。
K 是索引,V 是每次循环的具体元素。
// 由于回调函数是在当前DOM元素为上下文的语境中触发的,所以关键字 this 总是指向这个元素。 // 为每一个li标签加class $("li").each(function(){ $(this).addClass("c1"); });
注意: jQuery的方法返回一个jQuery对象,遍历jQuery集合中的元素 -- 被称为隐式迭代的过程。当这种情况发生时,它通常不需要显式地循环的 .each()
方法:
也就是说,上面的例子没有必要使用each()方法,直接像下面这样写就可以了:
$("li").addClass("c1"); // 对所有标签做统一操作
终止 each 循环
在遍历过程中可以使用 return false
提前结束each循环。
而直接使用return
后面什么都不加,不写false
,就是跳过本次循环的意思。
JS 和 jQuery 中的 for 循环也是通过他们两个来跳出当此循环或者终止循环
实例一:return false var a = [1,2,3,4,5,6,7,8] $.each(a, function(k,v){ if (v > 3){ // 大于3就结束循环 return false; }else{ console.log(v); } }); // 输出 1 2 3 实例二:return var a = [1,2,3,4,5,6,7,8] $.each(a, function(k,v){ if (v > 2 && v < 7){ // 在2-7之间的数字就跳过循环 return false; }else{ console.log(v); } }); // 输出 1 2 7 8
.data( ) 方法
任意 jQuery 对象都有 data 方法,可以保存任意值,可以用来代替全局变量
.data(key, value):设置值
描述:在匹配的元素上存储任意相关数据。
$("div").data("age",18); //给所有div标签都保存一个名为age,值为18
.data(key):取值,没有的话返回undefined
描述: 返回匹配的元素集合中的第一个元素的给定名称的数据存储的值
$("div").data("age"); //返回第一个div标签中保存的"age"的值
可以保存标签
$('div.c1').data('a标签',$('a.c2')); $('.c1').data('a标签').text(); -->百度
.removeData(key):删除
描述:移除存放在元素上的数据,不加key参数表示移除所有保存的数据。
$('.c1').removeData('a标签'); // 移除元素上存放’a标签‘对应的数据