JQuery总结

一、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 ——> 针对的是checked\selected\disabled
// 查看标签是否有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标签‘对应的数据

JQuery总结

上一篇:requests请求接口---上传文件


下一篇:Web前端自动化测试Cypress实践总结