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

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

函数 描述
.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 );//取值有两种方式1、数组名[i]  2、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>
时间: 2024-08-01 10:46:24

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

【javascript】详解变量,值,类型和宿主对象

前言 我眼中的<javascript高级程序设计> 和<你不知道的javascript>是这样的:如果<javascript高级程序设计>是本教科书的话, <你不知道的javascript>就是那本王后雄有以下两点: 1. 老师会教你: 考试最后的准备仍然要“回归课本”2. 在1的前提下并不妨碍我们希望拥有一本好用的“王后雄” JS数据类型 JS类型分类 讲到类型, 首先要说的当然是JS的类型分类, 对于这一点,<javascript高级语言程序设计&

二维数组(声明以及遍历)

首先图面理解二维数组(数组里面的元素不是字符或者数字类型而是另外一个数组)! 一,二维数组的声明 int[ ] [ ] arr; 初始化一个能存3个一维数组的二维数组 arr = new int [3] [ ];  (此时只声明了一个二维数组的空间,并没有声明一维数组的空间哈!!) 赋值: [3]赋值 int[] arr1 = {1,3,4,5}; int[] arr2 = {1,3,4}; int[] arr3 = {2,1,6,4}; arr[0] = arr1; arr[1] = arr2

[转发]for 循环,jQuery循环遍历详解

1.for 循环原生JS最基本的使用: for (var i=0;i<cars.length;i++) { ..... } for - 循环代码块一定的次数2.for infor/in - 循环遍历对象的属性以任意顺序遍历一个对象的可枚举属性.对于每个不同的属性,语句都会被执行 var obj = {a:1, b:2, c:3}; for (var prop in obj) { console.log("obj." + prop + " = " + obj[p

批处理命令 For循环命令详解

批处理for命令详解FOR这条命令基本上都被用来处理文本,但还有其他一些好用的功能!看看他的基本格式(这里我引用的是批处理中的格式,直接在命令行只需要一个%号)FOR 参数 %%变量名 IN (相关文件或命令) DO 执行的命令参数:FOR有4个参数 /d /l /r /f 他们的作用我在下面用例子解释%%变量名 :这个变量名可以是小写a-z或者大写A-Z,他们区分大小写,FOR会把每个读取到的值给他;IN:命令的格式,照写就是了;(相关文件或命令) :FOR要把什么东西读取然后赋值给变量,看下

【转】批处理命令 For循环命令详解!

批处理for命令详解FOR这条命令基本上都被用来处理文本,但还有其他一些好用的功能!看看他的基本格式(这里我引用的是批处理中的格式,直接在命令行只需要一个%号)FOR 参数 %%变量名 IN (相关文件或命令) DO 执行的命令参数:FOR有4个参数 /d /l /r /f 他们的作用我在下面用例子解释%%变量名 :这个变量名可以是小写a-z或者大写A-Z,他们区分大小写,FOR会把每个读取到的值给他;IN:命令的格式,照写就是了;(相关文件或命令) :FOR要把什么东西读取然后赋值给变量,看下

OpenCV学习C++接口 Mat像素遍历详解

OpenCV学习C++接口 Mat像素遍历详解 原文地址:https://www.cnblogs.com/zhehan54/p/8460602.html

Java 多维数组遍历详解

数组是Java中的一种容器对象,它拥有多个单一类型的值.当数组被创建的时候数组长度就已经确定了.在创建之后,其长度是固定的.下面是一个长度为10的数组: public class ArrayDemo { private int arraySize=10; public int[] arrayOfIntegers = new int[arraySize]; } 上面的代码是一维数组的例子.换句话说,数组长度只能在一个方向上增长.很多时候我们需要数组在多个维度上增长.这种数组我们称之为多维数组.为简

“全栈2019”Java第三十一章:二维数组和多维数组详解

难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第三十一章:二维数组和多维数组详解 下一章 "全栈2019"Java第三十二章:增强for循环Foreach语法 学习小组 加入同步学习小组,共同交流与进步. 方式一:关注头条号Gorhaf,私信"Java学习小组". 方式二:关注公众号Gorhaf,回复"Ja

二维数组作为函数参数深度详解

        前几天和同学讨论数组作为函数参数,感觉各种困惑.花了一些时间在网上查看了一些资料,并加上自己的理解.记录一下! 一. 指向指针的指针和指向数组的指针 很多人以为"指向数组的指针"就是"指向指针的指针",于是有人写这样的代码: int a[3][4]; int **p = a; //错误 数组实际类型是int [3][4],在作为右值时可以被转化为int (*)[4],它们都和int **不同,自然不可用. 那么,你要用一个指针来指向a,就要用一个