本文由 DTcms素材网 – DT素材网 发布,转载请注明出处,如有问题请联系我们!ES6中Iterator接口的代码示例讲解
收藏es6中,操作某些数据结构(array object map set)时,怎么用一个统一的方法操作,Iterator接口实现了这样的功能
1.Iterator在数组中的应用
{ let arr = ['hello', 'world']; // 数组内部实现了iterator接口,所以直接调用[Symbol.iterator]() let map = arr[Symbol.iterator](); console.log(map.next()); // {value: "hello", done: false} console.log(map.next()); // {value: "world", done: false} console.log(map.next()); // {value: undefined, done: true} // value 表示数组元素,done表示循环是否有下一步状态,true:没有下一步了,false:循环没有结束 }
2.自定义Iterator接口
{ // object没有内置iterator接口,自定义iterator接口,让obj也可以使用for...of let obj = { start: [1,2,3], end: [4,5,6], // 声明iterator接口方法 [Symbol.iterator]() { // 先遍历start,再遍历end let arr = this.start.concat(this.end); let index = 0; // 返回next() return { next() { if (index < arr.length) { return { value: arr[index++], done: false } } else { return { value: arr[index++], done: true } } } } } }; // for...of 实现的原理就是不断调用Iterator接口 // 通过 for...of 验证接口是否配置成功,如果没有配置成功,object就无法使用 for...of循环 for (let key of obj) { console.log(key); // 1 2 3 4 5 6 } }
3.for…of循环
{ // 数组内部实现了iterator接口,所以可以直接使用for...of循环 let arr = ['hello', 'world']; for (let value of arr) { console.log(value); // hello world } }
-
专栏
-
超级有温度的代码
-
文章详情
ican 26 发布于 超级有温度的代码
1 天前发布
【ES6入门13】:Iterator
-
前端
-
es6
-
javascript
14 次阅读 · 读完需要 6 分钟
0
es6中,操作某些数据结构(array object map set)时,怎么用一个统一的方法操作,Iterator接口实现了这样的功能
1.Iterator在数组中的应用
{ let arr = ['hello', 'world']; // 数组内部实现了iterator接口,所以直接调用[Symbol.iterator]() let map = arr[Symbol.iterator](); console.log(map.next()); // {value: "hello", done: false} console.log(map.next()); // {value: "world", done: false} console.log(map.next()); // {value: undefined, done: true} // value 表示数组元素,done表示循环是否有下一步状态,true:没有下一步了,false:循环没有结束 }
2.自定义Iterator接口
{ // object没有内置iterator接口,自定义iterator接口,让obj也可以使用for...of let obj = { start: [1,2,3], end: [4,5,6], // 声明iterator接口方法 [Symbol.iterator]() { // 先遍历start,再遍历end let arr = this.start.concat(this.end); let index = 0; // 返回next() return { next() { if (index < arr.length) { return { value: arr[index++], done: false } } else { return { value: arr[index++], done: true } } } } } }; // for...of 实现的原理就是不断调用Iterator接口 // 通过 for...of 验证接口是否配置成功,如果没有配置成功,object就无法使用 for...of循环 for (let key of obj) { console.log(key); // 1 2 3 4 5 6 } }
3.for…of循环
{ // 数组内部实现了iterator接口,所以可以直接使用for...of循环 let arr = ['hello', 'world']; for (let value of arr) { console.log(value); // hello world } }
-
-
举报
你可能感兴趣的
评论
默认排序 时间排序
载入中…
显示更多评论
更多 推荐文章
- 04-17中国首个东盟电子商务平台“美丽湾”启动
- 04-16电商下乡,京东、苏宁、阿里农村遭遇战打响?
- 04-16买房还是炒股,2015年买房无法拒绝的5大理由
- 04-161季度多家房企利润跌幅超50% 去库存促销战打响