首页 > 代码库 > JavaScript中遍历数组 最好不要使用 for in 遍历
JavaScript中遍历数组 最好不要使用 for in 遍历
先看一段代码
1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <title>Document</title> 6 </head> 7 <body> 8 9 <script>10 // 一个普通的数组 11 var arr =[3,5,2,6];12 // 普通的for 循环遍历13 for(var i = 0 ; i < arr.length; i++){14 console.log(i,"类型:"+typeof i,arr[i]);15 }16 // 用for in 遍历数组17 for(var k in arr){18 console.log(k,"类型:"+typeof k,arr[k]);19 }20 </script>21 </body>22 </html>
这段代码显示出了 一点 for循环遍历数组 和for in 循环遍历 数组的一点区别:
标准的for循环中的i是number类型,表示的是数组的下标,但是foreach循环中的i表示的是数组的key是string类型。
这还不是坑,只是一点区别。
再看一段代码
1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <title>Document</title> 6 </head> 7 <body> 8 9 <script>10 // 一个普通的数组 11 var arr =[3,5,2,6];12 // 在数组原型上扩展一个方法13 Array.prototype.extend = function(){14 console.log("在数组原型扩展一个方法");15 }16 // 普通的for 循环遍历17 for(var i = 0 ; i < arr.length; i++){18 console.log(i,"类型:"+typeof i,arr[i]);19 }20 // 用for in 遍历数组21 for(var k in arr){22 console.log(k,"类型:"+typeof k,arr[k]);23 }24 </script>25 </body>26 </html>
这段代码就是在上边的代码的基础上,为Array做了一下扩充。很简单,只是添加了一个函数。但是我们来看运行会出现了什么情况:
输出的结果中,多出了一行,这一行就是我们扩展的一个函数,不是我们定义在数组中的值。到此这个问题就出来了。
综上所述,用for...in...在通常情况下确实可以正确运行。
但是如果我们在项目采用的是用foreach遍历数组,假设有一天谁不小心自己为了扩展js原生的Array类,或者引入一个外部的js框架也扩展了原生Array。那问题就来了。
所以最好还是用for循环遍历数组
JavaScript中遍历数组 最好不要使用 for in 遍历
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。