这篇文章主要介绍了 jquery 中 object 对象循环遍历的方法,感兴趣的小伙伴们可以参考一下
jQuery 是一个兼容多浏览器的 javascript 框架,核心理念是 write less,do more(写得更少, 做得更多)。jQuery 在 2006 年 1 月由美国人 John Resig 在纽约的 barcamp 发布,吸引了来自世界各地的众多 JavaScript 高手加入,由 Dave Methvin 率领团队进行开发。
一个朋友问对象如何转为数组,当我问他为啥要转得时候,他告诉我,数组可以用 js 循环遍历,而对象则不可以。其实呢,对象同样可以循环遍历的啊。不用转换也可以循环!说明你对 js 或者 jquery 的某些操作不是很熟练!在这里我简单介绍一下!
案例
我们看如下对象:
- var data={
- 张三:69,
- 李四:72,
- 王五:90,
- 二麻子:88,
- 前端博客:100,
- haorooms : 98,
- 王大壮:99
- }
假如上面是后台返回的一个 key,一个是 value 的对象(这种对象相信大家经常遇到吧!),现在要把这个内容,循环绑定到一个表格中。有的朋友对对象的循环就不知道怎么操作了!今天我给大家介绍两个方法!
方法一:
用 $.each 的方式进行循环!
假如你不知道 $.each 的话,建议大家网上搜一搜。当然也可以搜索一下 "jquery 的 $().each,$.each 的区别 ",关于他们的区别,我在这里就不详细介绍了。可能有的朋友 $().each 这个方式用的比较多,今天主要给大家介绍 $.each。
$.each() 可以遍历数组和对象。方式如下:
- $.each([{"name": "haorooms",
- "email": "bb@126.com"
- },
- {"name": "qianduan",
- "email": "aa@hao.com"
- }],
- function(i, n) {
- alert("索引: " + i, "对应值为:" + n.name);
- });
也可以这么遍历:
- 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 循环!
另外,假如我们遇到如下对象:
- var data={
- 张三:69,
- 李四:72,
- 王五:90,
- 二麻子:88,
- 前端博客:100,
- haorooms : 98,
- 王大壮:99
- }
我们可以用 data.haorooms 得到 98, 但是我们用 "data. 前端博客" 会报错,因此,在我们用汉字做 key 值的时候,选取的时候应该用 data["前端博客"], 这种方式来选择,不要再用点号了。
来源: http://www.phperz.com/article/17/0216/268021.html