• jquery中object对象循环遍历的方法


    一个朋友问对象如何转为数组,当我问他为啥要转得时候,他告诉我,数组可以用js循环遍历,而对象则不可以。其实呢,对象同样可以循环遍历的啊。不用转换也可以循环!说明你对js或者jquery的某些操作不是很熟练!在这里我简单介绍一下!

    案例

    我们看如下对象:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    var data={
      张三:69,
      李四:72,
      王五:90,
      二麻子:88,
      前端博客:100,
      haorooms : 98,
      王大壮:99
    }

    假如上面是后台返回的一个key,一个是value的对象(这种对象相信大家经常遇到吧!),现在要把这个内容,循环绑定到一个表格中。有的朋友对对象的循环就不知道怎么操作了!今天我给大家介绍两个方法!

    方法一:

    用$.each的方式进行循环!

    假如你不知道$.each的话,建议大家网上搜一搜。当然也可以搜索一下“jquery的$().each,$.each的区别”,关于他们的区别,我在这里就不详细介绍了。可能有的朋友$().each这个方式用的比较多,今天主要给大家介绍$.each。

    $.each()可以遍历数组和对象。方式如下:

    1
    2
    3
    4
    $.each([{“name”:”haorooms”,”email”:”bb@126.com”},{“name”:”qianduan”,”email”:”aa@hao.com”}],function(i,n)
    {
    alert(“索引:”+i,”对应值为:”+n.name);
    });

    也可以这么遍历:

    1
    2
    3
    4
    var arr1 = [ “one”, “two”, “three”, “four”, “five” ];
    $.each(arr1, function(){
    alert(this);
    });

    输出:one   two  three  four   five
    最爽的是可以遍历数组:

    var obj =data;//上面复制的data
    $.each(obj, function(key, val) {
    alert(obj[key]);//可以输出成绩
    console.log(key);//可以输出姓名
    });

    方法二:

    用for in循环,可以遍历obj

    对上面的对象,我们可以这么写来循环!

    for(var i in data){
     console.dir(i);//输出姓名
     console.dir(data[i]);//输出分数
    }

    for in循环相信大家应该不陌生!for循环我们用到比较多的是for(var i=0;i<array.length;i++)这样,这个主要是针对数组来循环的。对于对象,我们通常用for in循环!

    另外,假如我们遇到如下对象:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    var data={
      张三:69,
      李四:72,
      王五:90,
      二麻子:88,
      前端博客:100,
      haorooms : 98,
      王大壮:99
    }

    我们可以用data.haorooms得到98,但是我们用“data.前端博客”会报错,因此,在我们用汉字做key值的时候,选取的时候应该用data["前端博客"],这种方式来选择,不要再用点号了。

  • 相关阅读:
    Springboot演示小Demo
    快速构建一个 Springboot
    javase练习题--每天写写
    javase练习题
    WebDriver API——延时操作及元素等待
    WebDriver API——javascript的相关操作
    Jenkins安装部署及tomcat的入门介绍
    WebDriver API——鼠标及键盘操作Actions
    sql查询练习
    睡前反省,絮叨絮叨
  • 原文地址:https://www.cnblogs.com/robinunix/p/7530759.html
Copyright © 2020-2023  润新知