JQuery中each()的使用方法说明


JQuery中的each函数在1.3.2的官方文档中的描述如下:
each(callback)
以每一个匹配的元素作为上下文来执行一个函数。
意味着,每次执行传递进来的函数时,函数中的this关键字都指向一个不同的DOM元素(每次都是一个不同的匹配元素)。而且,在每次执行函数时,都会给函数传递一个表示作为执行环境的元素在匹配的元素集合中所处位置的数字值作为参数(从零开始的整形)。返回 'false' 将停止循环 (就像在普通的循环中使用 'break')。返回 'true' 跳至下一个循环(就像在普通的循环中使用'continue')。
而后面的callback 则是回调函数,指示遍历元素的时候应该赋予的操作。先看下面的一个简单的例子:
迭代两个图像,并设置它们的 src 属性。注意:此处 this 指代的是 DOM 对象而非 jQuery 对象。
HTML 代码:

复制代码 代码如下:

<img/><img/>jQuery 代码:
$("img").each(function(i){
this.src = "test" + i + ".jpg";
});

结果:[ <img src="test0.jpg" />, <img src="test1.jpg" /> ]
当然,在遍历元素的时候,jquery是允许自定义跳出的,请看示例代码:你可以使用 'return' 来提前跳出 each() 循环。
HTML 代码:
复制代码 代码如下:

<button>Change colors</button>
<span></span>
<div></div>
<div></div>
<div></div>
<div></div>
<div id="stop">Stop here</div>
<div></div>
<div></div>
<div></div>

jQuery 代码:
复制代码 代码如下:

$("button").click(function(){
$("div").each(function(index,domEle){
$(domEle).css("backgroundColor","wheat");
if($(this).is("#stop")){
$("span").text("在div块为#"+index+"的地方停止。");
return false;
}
});

或者这么写:
复制代码 代码如下:

$("button").click(function(){
$("div").each(function(index){
$(this).css("backgroundColor","wheat");
if($(this).is("#stop")){
$("span").text("在div块为#"+index+"的地方停止。");
return false;
}
});

图解:



相关阅读:
用VBS模拟实现PHP的sha1_file函数效果代码
对javascript和select部件的结合运用
详解:虚拟主机IIS连接数知识
用PHP连mysql和oracle数据库性能比较
CSS实例:创建有图标的网站导航菜单
跳出惯性思维解决Linux上不了网的问题
C#教程:关于匿名类型的特性
Oracle10g新增CONVERT语法
Asp.net Mvc Framework 六 (更多的View传值及显示方式)
用javascript实现select的美化
系统技巧 制作闪存启动盘的思路
ORM中的继承关系映射全解
字符批量替换程序asp服务器版
数据字典表Truncate掉将导致数据库不可用
快速导航

Copyright © 2016 phpStudy |