jQuery$.each循环遍历详解,各类取值对比,$.each遍历数组、对象、Dom元素、二维数组、双层循坏、类json数据等等

jQuery 遍历函数包括了用于筛选、查找和串联元素的方法。html

函数 描述
.add() 将元素添加到匹配元素的集合中。
.andSelf() 把堆栈中以前的元素集添加到当前集合中。
.children() 得到匹配元素集合中每一个元素的全部子元素。
.closest() 从元素自己开始,逐级向上级元素匹配,并返回最早匹配的祖先元素。
.contents() 得到匹配元素集合中每一个元素的子元素,包括文本和注释节点。
.each() 对 jQuery 对象进行迭代,为每一个匹配元素执行函数。
.end() 结束当前链中最近的一次筛选操做,并将匹配元素集合返回到前一次的状态。
.eq() 将匹配元素集合缩减为位于指定索引的新元素。
.filter() 将匹配元素集合缩减为匹配选择器或匹配函数返回值的新元素。
.find() 得到当前匹配元素集合中每一个元素的后代,由选择器进行筛选。
.first() 将匹配元素集合缩减为集合中的第一个元素。
.has() 将匹配元素集合缩减为包含特定元素的后代的集合。
.is() 根据选择器检查当前匹配元素集合,若是存在至少一个匹配元素,则返回 true。
.last() 将匹配元素集合缩减为集合中的最后一个元素。
.map() 把当前匹配集合中的每一个元素传递给函数,产生包含返回值的新 jQuery 对象。
.next() 得到匹配元素集合中每一个元素紧邻的同辈元素。
.nextAll() 得到匹配元素集合中每一个元素以后的全部同辈元素,由选择器进行筛选(可选)。
.nextUntil() 得到每一个元素以后全部的同辈元素,直到遇到匹配选择器的元素为止。
.not() 从匹配元素集合中删除元素。
.offsetParent() 得到用于定位的第一个父元素。
.parent() 得到当前匹配元素集合中每一个元素的父元素,由选择器筛选(可选)。
.parents() 得到当前匹配元素集合中每一个元素的祖先元素,由选择器筛选(可选)。
.parentsUntil() 得到当前匹配元素集合中每一个元素的祖先元素,直到遇到匹配选择器的元素为止。
.prev() 得到匹配元素集合中每一个元素紧邻的前一个同辈元素,由选择器筛选(可选)。
.prevAll() 得到匹配元素集合中每一个元素以前的全部同辈元素,由选择器进行筛选(可选)。
.prevUntil() 得到每一个元素以前全部的同辈元素,直到遇到匹配选择器的元素为止。
.siblings() 得到匹配元素集合中全部元素的同辈元素,由选择器筛选(可选)。
.slice() 将匹配元素集合缩减为指定范围的子集。

<head> <script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script> <script> $(function(){ //设置默认选中项 $("select:eq(0)").val(2); //若是多选,将返回一个数组,其包含所选的值。 $.each($("select:eq(0)").val(),function(i,v){ //$("select:eq(0)").val()应返回一个数组 //遍历数组有5种方式 console.log(v); console.log(数组名[i]) //能用$(this)或者this的function()函数里就不用传值了 alert($(this)[0]);//不理解但能取出值 //=========this取值================ //$(this)[0] == this = v alert(this); alert(this[0]);//不理解但能取出值 }); //获取Select选中匹配元素的当前值,即[即便多选也只]取得第一个匹配元素的val内容,是字符串因此要split()转成数组 $.each($("select:eq(0) :selected").val().split(),function(i,v){ //一样5种方式 console.log(v); }); //例遍dom元素好比selcted选项 $.each($("select:eq(0) :selected"),function(i,v){//遍历选中的 //$.each($("select:eq(0) option"),function(i,v){//遍历所有元素 console.log(v);//遍历出<option value="2">香蕉</option>相似这种html元素 //注意取值 console.log(v.name); console.log(v.value); console.log(v.text); //=========this取值================= console.log(this)// 和上面取法相似,this至关于v console.log(this.name); console.log(this.value); console.log(this.text); //=======$(this)取值============ //$(this)[0] == this = v alert($(this).val()); alert($(this).text())======alert($(this).html()); }); //====================JQuery中使用each,若是须要退出 each 循环可以使回调函数返回 return false;=========================== //第一个为对象的成员名称或数组的索引,第二个为对应变量值或内容 //例遍数组,同时使用元素索引和内容。(i是索引,n是内容) $.each([0,1,2], function(i, n){ //遍历数组有5种方式 alert( "Item #" + i + ": " + n );//取值有两种方式一、数组名[i] 二、n alert(数组名[i]); //=========$(this)取值================ alert($(this)[0]);//不理解但能取出值 //=========this取值================ alert(this); alert(this[0]);//不理解但能取出值 }); //例遍对象,同时使用成员名称和变量内容。(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($("input:hidden"), function(i,val){ alert(val); //输出[object HTMLInputElement],由于它是一个表单元素。 alert(i); //输出索引为0,1,2,3 //注意底下取值 alert(val.name); //输出name的值 alert(val.value); //输出value的值 //=========this取值================= console.log(this)// 和上面取法相似,this至关于val console.log(this.name); console.log(this.value); console.log(this.text); //=========$(this)取值============ //$(this)[0] == this = v alert($(this).val()); alert($(this).text())======alert($(this).html()); }); //================================================================== //事实证实双层循坏this,$(this)无论用,只能用function()里的函数value //循坏二维数组 $.each([[1, 4, 3], [4, 6, 6], [7, 20, 9]] , function(i, item){ $.each(item,function(k,v){//item至关于取每个一维数组, console.log(v); }); }); //循坏多个对象【经常使用在json串中】 $.each( [{ name: "a", lang: "b" },{ name: "John", lang: "JS" }], function(i, n){ $.each(n,function(k,v){ alert( "Name: " + k + ", Value: " + v ); }); }); 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方法,很方便。*/ }); </script> </head> <table> <tr> <td> <!--multiple设定下拉框能够多选,size设定下拉框不呈现下拉方式,--> <select size="12" id="One" multiple="multiple"> <option value='1'>苹果</option> <option value="2">香蕉</option> <option value="3">草莓</option> <option value="4">橘子</option> </select> </td> <td> <input type="button" value=">>>"><br> <input type="button" value="&nbsp;>&nbsp;"><br> <input type="button" value="&nbsp;<&nbsp;"><br> <input type="button" value="<<<"><br> </td> <td> <select size="12" id="two" multiple="multiple"> <option value="5">葡萄</option> </select> </td> <td> <input type="button" value="&nbsp;up&nbsp;"><br><br> <input type="button" value="down"><br> </td> </tr> </table>
相关文章
相关标签/搜索