下面说一下for… in语句。可直接把下面的代码复制到浏览器的控制台或Node环境下去执行。
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
//用来快速迭代对象。
var o ={name:'dylan',age:24,num:110}; for(var test in o){ console.log("o["+test+"]= "+o[test]); } console.log("~~~~~~~~~~~") Object.prototype.getName =function(){return this.name}; o.getAge=function(){returnthis.age};
for(var test in o){ console.log("o["+test+"]= "+o[test]); } console.log(o.getName()+o.getAge());
//getName并不是o的方法,它是Object原型方法,而Object原型方法会被
//所有Object类型实例对象所继承的.
//因此可以看出使用for...in语句不仅能迭代出对象的属性,还可迭代出其原型方法。
console.log("~~~~hasOwnPyroperty~~~~~~~"); for(var test in o){ if(o.hasOwnProperty(test)){ console.log("o["+test+"]= "+o[test]); } }
//通过调用hasOwnProperty方法过滤原型中的方法。
//如果o有二个undefined和null属性呢?.
o.undefined ='undefined'; o.null = 'null'; console.log(o); console.log(o.toString()); console.log(o.valueOf());
for(var test in o){ if(o.hasOwnProperty(test)){ console.log("o["+test+"]= "+o[test]); } }
//如果 o=null;
o=undefined; //o=null; for(var test in o){ if(o.hasOwnProperty(test)){ console.log("o["+test+"]= "+o[test]); } }
//既不会报错,也不会输出。但如果是在低版本浏览器,很有可能报异常。因此在使用
//for-in之前,可以先过滤一下迭代对象是否为null或undefined.
console.log("~~~~Iteratearray~~~~~~~");
//迭代数组可以吗?
var a = [26,'hellworld',newDate()]; for(var pro in a){ console.log("a["+pro+"]="+a[pro]); }
//Array也是一种对象,因此原型的getName方法同样被迭代出来。
function keys(obj){ var aRaa = []; var i=0; for(aRaa[i++] in obj); return aRaa; } console.log(keys(o)); a.index = a.length; console.log(a); console.log(keys(a));
//当你以为是对象数组时,执行下面一条语句,发现又会发错。
//console.log(a[index]); //报错,index未定义
//但是下面这条语句不会报错。
console.log(a.index);
console.log(a[getName]);
//当迭代数组时,尽量少用for....in 语句,这样可以减少不必要的错误。用下面的常用方法,更好!
for(var i=0,lenght =a.length;i<lenght;i++){ console.log(a[i]); };
【Dylan童鞋】
关注Dylan童鞋,请搜索微信号:DylanTongXue 。
推送时间为:周一,周三,周四,周日晚上9:20分左右。
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
查看历史记录请回复1~9之间的数字。比如查看第六篇文章直接回复数字:6 。显示本帮助菜单,回复"H"。