for/in 循環遍歷對象的屬性

for/in 語句循環遍歷對象的屬性。 
js中獲取key獲得某對象中相對應的value的方法:obj.key 
js中根據動態key獲得某對象中相對應的value的方法有二: 
1、var key = "name1";var value = obj[key]; 
2、var key = "name1";var value = eval("obj."+key); java

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 循環遍歷對象的屬性時,原型鏈上的全部屬性都將被訪問spa

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 方法, 這將會避免原型對象擴展帶來的干擾:,只會訪問對象獨有的屬性:
prototype

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自身屬性的個數.code

keys.length;//"3"
相關文章
相關標籤/搜索