each的用法

news/2025/2/5 14:04:44/

1.数组中的each

复制代码
复制代码var arr = [ "one", "two", "three", "four"];     $.each(arr, function(){     alert(this);     });   
//上面这个each输出的结果分别为:one,two,three,four    var arr1 = [[1, 4, 3], [4, 6, 6], [7, 20, 9]]     
$.each(arr1, function(i, item){     alert(item[0]);     
});     
//其实arr1为一个二维数组,item相当于取每一个一维数组,   
//item[0]相对于取每一个一维数组里的第一个值   
//所以上面这个each输出分别为:1   4   7     var obj = { one:1, two:2, three:3, four:4};     
$.each(obj, function(i) {     alert(obj[i]);           
});   
//这个each就有更厉害了,能循环每一个属性     
//输出结果为:1   2  3  4 
复制代码

 

2.遍历Dom元素中

复制代码
<html>
<head>
<script type="text/javascript" src="/jquery/jquery.js"></script>
<script type="text/javascript">
$(document).ready(function(){$("button").click(function(){$("li").each(function(){alert($(this).text())});});
});
</script>
</head>
<body>
<button>输出每个列表项的值</button>
<ul>
<li>Coffee</li>
<li>Milk</li>
<li>Soda</li>
</ul>
</body>
</html>
复制代码

依次弹出Coffee,Milk,Soda

 

 3.each和map的比较

下面的例子是获取每一个多框的ID值;

each方法:

定义一个空数组,通过each方法,往数组添加ID值;最后将数组转换成字符串后,alert这个值;

复制代码
复制代码
$(function(){var arr = [];$(":checkbox").each(function(index){arr.push(this.id);});var str = arr.join(",");alert(str);
})
复制代码
复制代码

 

map方法:

将每个:checkbox执行return this.id;并将这些返回值,自动的保存为jQuery对象,然后用get方法将其转换成原生Javascript数组,再使用join方法转换成字符串,最后alert这个值;

复制代码
$(function(){var str = $(":checkbox").map(function() {return this.id;}).get().join();    alert(str);
})
复制代码

当有需一个数组的值的时候,用map方法,很方便。

 

 4.jquery中使用each

例遍数组,同时使用元素索引和内容。(i是索引,n是内容)

代码如下:

$.each( [0,1,2], function(i, n){
alert( "Item #" + i + ": " + n );
}); 
例遍对象,同时使用成员名称和变量内容。(i是成员名称,n是变量内容)
代码如下:
$.each( { name: "John", lang: "JS" }, function(i, n){
alert( "Name: " + i + ", Value: " + n );
}); 

例遍dom元素,此处以一个input表单元素作为例子。 
如果你dom中有一段这样的代码 
<input name="aaa" type="hidden" value="111" /> 
<input name="bbb" type="hidden" value="222" /> 
<input name="ccc" type="hidden" value="333" /> 
<input name="ddd" type="hidden" value="444"/> 
然后你使用each如下

代码如下:
复制代码
$.each($("input:hidden"), function(i,val){
alert(val); //输出[object HTMLInputElement],因为它是一个表单元素。
alert(i); //输出索引为0,1,2,3
alert(val.name); //输出name的值
alert(val.value); //输出value的值
}); 
复制代码

 

5.each中根据this查找元素

实现效果”回复”两个字只有在鼠标经过的时候才显示出来

复制代码
<ol class="commentlist"><li class="comment"><div class="comment-body"><p>嗨,第一层评论</p><div class="reply"><a href="#" class=".comment-reply-link">回复</a></div></div><ul class="children"><li class="comment"><div class="comment-body"><p>第二层评论</p><div class="reply"><a href="#" class=".comment-reply-link">回复</a></div></div></li></ul></li>
</ol>
复制代码

js代码如下

$("div.reply").hover(function(){$(this).find(".comment-reply-link").show();
},function(){$(this).find(".comment-reply-link").hide();
});

实现效果,验证判断题是否都有选择

html

复制代码
<ul id="ulSingle"><li class="liStyle">1.&nbsp;&nbsp;阿斯顿按时<label id="selectTips" style="display: none" class="fillTims">请选择</label><!--begin选项--><ul><li class="liStyle2"><span id="repSingle_repSingleChoices_0_labOption_0">A         </span>.阿萨德发<input type="hidden" name="repSingle$ctl00$repSingleChoices$ctl00$hidID" id="repSingle_repSingleChoices_0_hidID_0" value="1" /><input id="repSingle_repSingleChoices_0_cheSingleChoice_0" type="checkbox" name="repSingle$ctl00$repSingleChoices$ctl00$cheSingleChoice" /></li><li class="liStyle2"><span id="repSingle_repSingleChoices_0_labOption_1">B         </span>.阿萨德发<input type="hidden" name="repSingle$ctl00$repSingleChoices$ctl01$hidID" id="repSingle_repSingleChoices_0_hidID_1" value="2" /><input id="repSingle_repSingleChoices_0_cheSingleChoice_1" type="checkbox" name="repSingle$ctl00$repSingleChoices$ctl01$cheSingleChoice" /></li><li class="liStyle2"><span id="repSingle_repSingleChoices_0_labOption_2">C         </span>.阿斯顿<input type="hidden" name="repSingle$ctl00$repSingleChoices$ctl02$hidID" id="repSingle_repSingleChoices_0_hidID_2" value="3" /><input id="repSingle_repSingleChoices_0_cheSingleChoice_2" type="checkbox" name="repSingle$ctl00$repSingleChoices$ctl02$cheSingleChoice" /></li></ul><!--end选项--><br /></li></ul>
复制代码

js代码

复制代码
        //验证单选题是否选中$("ul#ulSingle>li.liStyle").each(function (index) {//选项个数var count = $(this).find("ul>li>:checkbox").length;var selectedCount = 0for (var i = 0; i < count; i++) {if ($(this).find("ul>li>:checkbox:eq(" + i + ")").attr("checked")) {selectedCount++;break;}}if (selectedCount == 0) {$(this).find("label#selectTips").show();return false;}else {$(this).find("label#selectTips").hide();}})
复制代码

 ps:传说中attr("property", "value");在部分浏览器中不管用可以用prop,如果只是判断可以用$(this).find("ul>li>:checkbox:eq(" + i + ")").is(":checked");

 

6.官方解释
以下是官方的解释: 

jQuery.each(object, [callback]) 

概述 
通用例遍方法,可用于例遍对象和数组。 

不同于例遍 jQuery 对象的 $().each() 方法,此方法可用于例遍任何对象。回调函数拥有两个参数:第一个为对象的成员或数组的索引,第二个为对应变量或内容。如果需要退出 each 循环可使回调函数返回 false,其它返回值将被忽略。 

参数 
objectObject 
需要例遍的对象或数组。 

callback (可选)Function 
每个成员/元素执行的回调函数。


http://www.ppmy.cn/news/544020.html

相关文章

eggs和egg是什么意思_egg是什么

展开全部 egg 英 [eɡ] 美 [ɛɡ] 形容词: eggless 过去式: egged 过去分词: egged 现在分词: egging 第三32313133353236313431303231363533e58685e5aeb931333335313064人称单数: eggs n.蛋&#xff1b;卵&#xff1b;蛋形物 vt.用蛋覆盖&#xff1b;向 ... 扔蛋 vt.怂恿&…

linux下挂载移动硬盘(ntfs格式)

工作中遇到linux系统 Red Hat Enterprise5.7 挂载希捷ntfs格式移动硬盘&#xff0c;会跳出一个ERROR提示框&#xff1a;The volume ‘EAGET-NQH’user the ntfs file system which is not supported by your system. 其中‘EAGET-NQH’为我的移动硬盘名。 查找资料发现linux支…

egg的基本使用

1.首先在编辑器的终端里面&#xff0c;通过脚手架创建基于egg的项目&#xff1a; mkdir egg-example && cd egg-example npm init egg --typesimple npm i 2.编写Controller: 如果你熟悉 Web 开发或 MVC&#xff0c;肯定猜到我们第一步需要编写的是 Controller 和 Rout…

fgets()

在写网络编程时候遇到一个问题&#xff1a;通过fgets读取到了一行输入到缓冲区中&#xff0c;总是要通过strlen()来查下缓冲区中的长度&#xff0c;然后替换。 一开始没懂这个操作&#xff0c;后来查了下资料&#xff0c;原来fgets在读取输入流的时候&#xff0c;会读取你最后…

egg使用egg-socket.io

下载 npm i egg-socket.io --save 使用 plugin.js module.exports.io {enable: true,package: egg-socket.io, }// config.default.js config.io {init: { }, // passed to engine.ionamespace: {/: {connectionMiddleware: [connection],packetMiddleware: [],},/example: …

e.target与e.currentTarget的作用

要说清楚这个东西&#xff0c;还不太好阐述呢&#xff0c;所以&#xff0c;先看看下面的代码&#xff1a; <!DOCTYPE html> <html> <head lang"en"><meta charset"UTF-8"><title></title><style type"text/c…

e.target和e.currentTarget的区别

e.target和e.currentTarget的区别 currentTarget始终是监听事件者&#xff0c;即 直接调用addEventlistener那个节点 而target是事件的真正发出者&#xff0c; 即 触发事件的节点&#xff0c;在click事件中就是被点击的节点。 详解 当触发一个元素的事件时&#xff0c;该事件…

for each 的用法

for each 的语句格式&#xff1a; for(元素类型t 元素变量x : 遍历对象obj){ 引用了x的java语句; } Java 中新增的 for each 的用法 JDK1.5加入的增强for和循环. for each语句使用总结增强for(part1:part2){part3}; part2中是一个数组对象,或者是带有泛性的集合. part1定…