for in遍历对象属性注意事项

// 使用 for in 循环遍历对象的属性时,原型链上的所有属性都将被访问:
Object.prototype.bar = 10;// 修改Object.prototype
var obj = {x:1,y:2,z:3};
var keys = [],values = [],i=0;
for(i in obj){
// console.log(i);
keys.push(i);
values.push(obj[i])
console.log(i+":"+obj[i]);//遍历对象属性值的方法
console.log(i+":"+eval('obj.'+i));//遍历对象属性值的方法
}
console.log(keys);//["x", "y", "z", "bar"]
console.log(values);//[1, 2, 3, 10]
// 推荐总是使用 hasOwnProperty 方法,这将会避免原型对象扩展带来的干扰:
function allpro(obj){
var keys = [],values = [];
for (var key in obj){
//只遍历对象自身的属性,而不包含继承于原型链上的属性
if(obj.hasOwnProperty(key) === true){
keys.push(key);
values.push(obj[key]);
}
}
console.log(keys+';'+values);
}
var objdata = {name:'aaa',age:'23',sex:"girl"};
allpro(objdata);//name,age,sex;aaa,23,girl

猜你喜欢

转载自www.cnblogs.com/studyh5/p/9216375.html