当前位置:网站首页>说说js中使用for in遍历数组存在的bug
说说js中使用for in遍历数组存在的bug
2022-08-01 05:18:00 【儒雅的烤地瓜】
*****for in数组遍历的坑*****
对数组使⽤for in遍历,我们会遇到⼀个很严重的bug,那就是for in会遍历到数组添加到原型链上的属性,也就是说作用于数组的for-in循环体除了遍历数组元素外,还会遍历自定义的属性。
1. 当我们对数组使用for in遍历时
Array.prototype.istrue = function(value) {return true;}
var a = [1,2];
for(var i in a) {
console.log(a[i]);
}
输出结果:
1
2
function(value) {return true;}
所以,数组的遍历中不推荐使用for in,而使用forEach或是for of代替,由于forEach只能遍历索引数组,而for of能遍历数字下标的一切,即索引数组、类数组对象、字符串,所以我们⼀般遍历数组推荐使用for of代替forEach、for in。注:上⾯的i变量是string,并不是number
2. ⼀般的,我们对对象的遍历通常使用for in
var a = {"x":1,"y":2};
for(var i in a) {
console.log(a[i]);}
输出结果:
1
2
3. 如果使⽤了for in遍历数组,就⽤hasOwnProperty来规避遍历到原型链上的属性或⽅法
Array.prototype.istrue = function(value) {return true;}
var a = [1,2];
for(var i in a) {
if(a.hasOwnProperty(i){
console.log(a[i]);
})
}
输出结果:
1
2
边栏推荐
猜你喜欢
随机推荐
Selenium: mouse, keyboard events
Code Interview Guide for Programmers CD15 Generating an Array of Windowed Maximums
对话MySQL之父:一个优秀程序员可抵5个普通程序员
LeetCode 27. 移除元素
可视化全链路日志追踪
Selenium:上传、下载文件
leetcode125 验证回文串
(2022 Niu Ke Duo School IV) K-NIO's Sword (Thinking)
2022年超全的Android面经(附含面试题|进阶资料)
2022.7.26 模拟赛
WPF项目-按着键盘方向键,移动格子盒子效果
Seleniu:元素常用操作
Selenium: element judgment
56:第五章:开发admin管理服务:9:开发【文件上传到,MongoDB的GridFS中,接口】;(把文件上传到GridFS的SOP)
万字逐行解析与实现Transformer,并进行德译英实战(三)
LeetCode 9. 回文数
【MySQL必知必会】 表的优化 | 充分利用系统资源
pytroch、tensorflow对比学习—使用GPU训练模型
SL-12/2过流继电器
Selenium: form switching









