详谈js中标准for循环与foreach(for in)的区别
2017-11-02 09:54
696 查看
js中遍历数组的有两种方式
var array=['a'] //标准的for循环 for(var i=1;i<array.length;i++){ alert(array[i]) } //foreach循环 for(var i in array){ alert(array[i]) }
正常情况下上面两种遍历数组的方式结果一样。首先说两者的第一个区别
标准的for循环中的i是number类型,表示的是数组的下标,但是foreach循环中的i表示的是数组的key是string类型,因为js中一切皆为对象。自己试试 alert(typeof i);这个区别是小问题。现在我加上如下代码,上面的执行结果就不一样了。
//扩展了js原生的Array Array.prototype.test=function() }
试试看上面的代码执行什么。我们发现标准的for循环任然真正的对数组循环, 但是此时foreach循环对我刚才写的test方法写打印出来了。这就是for与foreach遍历数组的最大区别,如果我们在项目采用的是用foreach遍历数组,假设有一天谁不小心自己为了扩展js原生的Array类,或者引入一个外部的js框架也扩展了原生Array。那问题就来了。再此建议两点
不要用for in遍历数组,全部统一采用标准的for循环变量数组( 我们无法保证我们引入的js是否会采用prototype扩展原生的Array )
如果要对js的原生类扩展的时候,不要采用prototype了
以上这篇详谈js中标准for循环与foreach(for in)的区别就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章推荐
- js中标准for循环与foreach(for in)的区别
- js中关于for循环、for in、foreach、for each in
- JS数组的遍历方式for循环与for...in
- foreach(增强for循环)和for的区别
- foreach和for in each 的区别
- for...in、for...of、forEach、map的区别
- 老生常谈foreach(增强for循环)和for的区别
- JS中for与for each in的区别
- js中for in 和 for each in的用法和区别
- ios中for循环和for-in循环的用法和区别
- js中for in 和 for each in的用法和区别
- 详谈js使用in和hasOwnProperty获取对象属性的区别
- js中的循环遍历数组中的元素,ES6(for-of)、ES5(forEach、for-in)、通用(for(i=0;i<length;i++))
- js - for,(for...in...),forEach(...),(for...of..)差异与原理浅析
- JS中的 map, filter, some, every, forEach, for...in, for...of 用法总结
- JS数组的遍历方式for循环与for...in
- 使用splice函数对数组中的元素进行删除for循环和for...in的区别
- JS:for...in...,Objects.keys()和Object.getOwnPropertyNames的区别
- js 中 foreach循环(for in)中,最后会多出一个值
- for循环和for in循环以及for of循环的区别