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"