时间:2021-05-26
先看一段代码
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>Document</title></head><body> <script> // 一个普通的数组 var arr =[3,5,2,6]; // 普通的for 循环遍历 for(var i = 0 ; i < arr.length; i++){ console.log(i,"类型:"+typeof i,arr[i]); } // 用for in 遍历数组 for(var k in arr){ console.log(k,"类型:"+typeof k,arr[k]); } </script></body></html>这段代码显示出了 一点 for循环遍历数组 和for in 循环遍历 数组的一点区别:
标准的for循环中的i是number类型,表示的是数组的下标,但是foreach循环中的i表示的是数组的key是string类型。
这还不是坑,只是一点区别。
再看一段代码
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>Document</title></head><body> <script> // 一个普通的数组 var arr =[3,5,2,6]; // 在数组原型上扩展一个方法 Array.prototype.extend = function(){ console.log("在数组原型扩展一个方法"); } // 普通的for 循环遍历 for(var i = 0 ; i < arr.length; i++){ console.log(i,"类型:"+typeof i,arr[i]); } // 用for in 遍历数组 for(var k in arr){ console.log(k,"类型:"+typeof k,arr[k]); } </script></body></html>这段代码就是在上边的代码的基础上,为Array做了一下扩充。很简单,只是添加了一个函数。但是我们来看运行会出现了什么情况:
输出的结果中,多出了一行,这一行就是我们扩展的一个函数,不是我们定义在数组中的值。到此这个问题就出来了。
综上所述,用for...in...在通常情况下确实可以正确运行。
但是如果我们在项目采用的是用foreach遍历数组,假设有一天谁不小心自己为了扩展js原生的Array类,或者引入一个外部的js框架也扩展了原生Array。那问题就来了。
所以最好还是用for循环遍历数组
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
PHP中遍历数组有三种常用的方法:一、使用for语句循环遍历数组;二、使用foreach语句遍历数组;三、联合使用list()、each()和while循环遍历
vue中循环遍历使用的指令是v-for1.v-for遍历数组(1)valueinarr遍历数组中的元素(2)(value,index)inarr遍历数组中的元素
尽管数组在Javascript中是对象,但是不建议使用forin循环来遍历数组,实际上,有很多理由来阻止我们对数组使用forin循环。因为forin循环将会枚举
例,for(){}遍历数组 代码如下: 例,forin循环遍历数组 代码如下:varxvarmyarray=newArray()myarray[0]=
通常在JavaScript中用for与forin遍历数组结果是没有什么区别的,它的循环变量i都是从0开始的数组索引(forin如果遍历的是非数组对象的属性集合,