Error: for..in loops iterate over the entire prototype chain

本文介绍了ESLint在for...in循环中报错的原因,即可能遍历到原型链上的属性。提供了通过hasOwnProperty检查和使用Object.keys/Object.entries替代的传统方法,以确保代码只遍历预期的对象自身属性。
部署运行你感兴趣的模型镜像

ESLint报错: for…in loops iterate over the entire prototype chain, which is virtually never what you want.


原因

for…in会遍历整个原型链,可能会出现我们不想遍历到的属性,例如

class A {
  constructor() {
    this.a = 'va'
  }
};
A.prototype.todo = () => 'todo';

let a = new A();
for(let k in a) { // for..in 遍历
  console.log(k)
}
// a  todo
console.log(Object.keys(a));
// [a]
解决

添加hasOwnProperty判断,或
改为使用Object.keysObject.entries,这两个方法不会遍历原型链上的属性

class A {
  constructor() {
    this.a = 'va'
  }
};
A.prototype.todo = () => 'todo';

let a = new A();

for(let k in a)
  if(a.hasOwnProperty(k))
    console.log(k) // a

Object.keys(a).forEach((k) => console.log(k)); // a

Object.entries(a).forEach((e) => console.log(e)); // ['a', 'va']

备注: hasOwnProperty可以兼容到ES3,Object.keysObject.entries分别是ES6及ES8中引入的,但是经过Babel打包后,这个区别可以忽略不计

您可能感兴趣的与本文相关的镜像

Wan2.2-T2V-A5B

Wan2.2-T2V-A5B

文生视频
Wan2.2

Wan2.2是由通义万相开源高效文本到视频生成模型,是有​50亿参数的轻量级视频生成模型,专为快速内容创作优化。支持480P视频生成,具备优秀的时序连贯性和运动推理能力

评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值