// 使用 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