JavaScript进阶系列——for in 循环
程序员文章站
2022-04-02 12:15:13
...
使用 hasOwnProperty 过滤
总结
和 in 操作符一样,for in 循环同样在查找对象属性时遍历原型链上的所有属性。
// 修改 Object.prototype Object.prototype.bar = 1; var foo = {moo: 2}; for(var i in foo) { console.log(i); // 输出两个属性:bar 和 moo }
由于不可能改变 for in 自身的行为,因此有必要过滤出那些不希望出现在循环体中的属性, 这可以通过 Object.prototype 原型上的hasOwnProperty 函数来完成。
注意:for in 循环不会遍历那些 enumerable 设置为 false的属性;比如数组的 length属性。
使用 hasOwnProperty 过滤
// foo 变量是上例中的 for(var i in foo) { if (foo.hasOwnProperty(i)) { console.log(i); } }
这个版本的代码是唯一正确的写法。由于我们使用了 hasOwnProperty,所以这次只输出 moo。 如果不使用 hasOwnProperty,则这段代码在原生对象原型(比如 Object.prototype)被扩展时可能会出错。
一个广泛使用的类库 Prototype 就扩展了原生的 JavaScript 对象。 因此,当这个类库被包含在页面中时,不使用 hasOwnProperty 过滤的 for in 循环难免会出问题。
注意:由于 for in 总是要遍历整个原型链,因此如果一个对象的继承层次太深的话会影响性能。
总结
推荐总是使用 hasOwnProperty,不要对代码运行的环境做任何假设,不要假设原生对象是否已经被扩展了。
以上就是JavaScript进阶系列——for in 循环的内容,更多相关内容请关注PHP中文网(www.php.cn)!
上一篇: css怎么设置文字1行
下一篇: php怎么实现相似查找
推荐阅读
-
JavaScript进阶教程(第二课)第1/3页_基础知识
-
javascript深拷贝、浅拷贝和循环引用深入理解
-
javascript进阶-原型prototype
-
javascript中利用数组实现的循环队列代码_javascript技巧
-
JavaScript设计模式系列三:建造者模式
-
Javascript循环绑定事件的示例代码_javascript技巧
-
js和jquery中循环的退出和继续学习记录_javascript技巧
-
深入理解JavaScript系列(4) 立即调用的函数表达式_javascript技巧
-
js 优化次数过多的循环 考虑到性能问题_javascript技巧
-
从零开始学_JavaScript_系列(37)——让浏览器支持es7特性