码迷,mamicode.com
首页 > 其他好文 > 详细

for/in 循环遍历对象的属性

时间:2015-09-22 00:14:37      阅读:143      评论:0      收藏:0      [点我收藏+]

标签:

for/in 语句循环遍历对象的属性。 
js中获取key得到某对象中相对应的value的方法:obj.key 
js中根据动态key得到某对象中相对应的value的方法有二: 
一、var key = "name1";var value = obj[key]; 
二、var key = "name1";var value = eval("obj."+key); 

JS代码:

var obj={"name":"wjy","age":26,"sex":"female"};//定义一个object对象  
var keys=[];//定义一个数组用来接受key  
var values=[];//定义一个数组用来接受value  
      for(var key in obj){  
            keys.push(key);  
            values.push(obj[key]);//取得value   
            alert(eval("obj."+key));//循环内逐一打印value值  
        }  
alert(obj.name);//wjy  
alert("keys is :"+keys+" and values is :"+values);  
//keys is : name,age,sex and values is : wjy,26,female

1.使用 for in 循环遍历对象的属性时,原型链上的所有属性都将被访问

Object.prototype.bar = 10;// 修改Object.prototype  
var obj={"name":"wjy","age":26,"sex":"female"};//定义一个object对象    
var keys=[];//定义一个数组用来接受key    
var values=[];//定义一个数组用来接受value    
  for(var key in obj){    
    keys.push(key);    
    values.push(obj[key]);//取得value      
    }    
alert("keys is :"+keys+" and values is :"+values);   
//keys is : name,age,sex,bar and values is : wjy,26,female,10

2. 推荐总是使用 hasOwnProperty 方法, 这将会避免原型对象扩展带来的干扰:,只会访问对象独有的属性:

function allpro(obj){  
    var keys=[];   
    var values=[];    
    for(var key in obj){   
        //只遍历对象自身的属性,而不包含继承于原型链上的属性。  
        if (obj.hasOwnProperty(key) === true){  
            keys.push(key);    
            values.push(obj[key]);   
            }                 
        }  
    alert("keys is :"+keys+" and values is :"+values);    
}  
Object.prototype.bar = 1;// 修改Object.prototype  
var o={"name":"wjy","age":26,"sex":"female"};//定义一个object对象   
allpro(o);  
//keys is : name,age,sex and values is: wjy,26,female


object对象没有length属性,所以不能直接通过for(var i=0;i<object.length;i++)的方式来访问,可以通过遍历得到key值的数组的长度来获取object自身属性的个数.

keys.length;//"3"




for/in 循环遍历对象的属性

标签:

原文地址:http://my.oschina.net/u/2331760/blog/509383

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!