javascript给对象添加迭代器

迭代器是啥就自行百度了

为啥for...of可以遍历数组,为啥不能遍历对象,就是for...of会调用迭代器,而数组是内置了迭代器了,而对象没有内置,所以直接使用for...of遍历对象会报错,因此只用在对象的原型上面自定义一个迭代器就好了

手动添加迭代器

javascript 复制代码
    Object.prototype[Symbol.iterator] = function* iterEntries() {
    let keys = Object.keys(this);
    for (let i = 0; i < keys.length; i++) {
        let key = keys[i];
        yield this[key];
    }
}

这里的yield是每次迭代返回的值,你可以设置为1,这样for...of对象的时候,就全是1了

相关推荐
bug爱好者8 分钟前
Vue3 基于Element Plus 的el-input,封装一个数字输入框组件
前端·javascript
乔公子搬砖18 分钟前
小程序开发提效:npm支持、Vant Weapp组件库与API Promise化(八)
前端·javascript·微信小程序·js·promise·vagrant·事件绑定
m0_4805026419 分钟前
Rust 登堂 之 函数式编程(三)
开发语言·后端·rust
没烦恼3011 小时前
登录表单提交:按钮点击事件 vs form submit事件,该如何选择?
javascript
eqwaak03 小时前
科技信息差(8.26)
大数据·开发语言·人工智能·编辑器
掘金安东尼3 小时前
Rspack 推出 Rslint:一个用 Go 编写的 TypeScript-First Linter
前端·javascript·github
黑客影儿4 小时前
在Godot中为您的游戏添加并控制游戏角色的完整技术指南
开发语言·游戏·游戏引擎·godot·gdscript·游戏开发·3d游戏
蓝胖子的小叮当4 小时前
JavaScript基础(十四)字符串方法总结
前端·javascript
yaoxin5211234 小时前
168. Java Lambda 表达式 - 专用比较器
java·开发语言
shylyly_5 小时前
Linux->多线程3
java·linux·开发语言·阻塞队列·生产者消费者模型