当前位置:Gxlcms > JavaScript > ES6中Iterator接口的代码示例讲解

ES6中Iterator接口的代码示例讲解

时间:2021-07-01 10:21:17 帮助过:6人阅读

本篇文章给大家带来的内容是关于ES6中Iterator接口的代码示例讲解,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

es6中,操作某些数据结构(array object map set)时,怎么用一个统一的方法操作,Iterator接口实现了这样的功能

1.Iterator在数组中的应用

  1. {
  2. let arr = ['hello', 'world'];
  3. // 数组内部实现了iterator接口,所以直接调用[Symbol.iterator]()
  4. let map = arr[Symbol.iterator]();
  5. console.log(map.next()); // {value: "hello", done: false}
  6. console.log(map.next()); // {value: "world", done: false}
  7. console.log(map.next()); // {value: undefined, done: true}
  8. // value 表示数组元素,done表示循环是否有下一步状态,true:没有下一步了,false:循环没有结束
  9. }

2.自定义Iterator接口

  1. {
  2. // object没有内置iterator接口,自定义iterator接口,让obj也可以使用for...of
  3. let obj = {
  4. start: [1,2,3],
  5. end: [4,5,6],
  6. // 声明iterator接口方法
  7. [Symbol.iterator]() {
  8. // 先遍历start,再遍历end
  9. let arr = this.start.concat(this.end);
  10. let index = 0;
  11. // 返回next()
  12. return {
  13. next() {
  14. if (index < arr.length) {
  15. return {
  16. value: arr[index++],
  17. done: false
  18. }
  19. } else {
  20. return {
  21. value: arr[index++],
  22. done: true
  23. }
  24. }
  25. }
  26. }
  27. }
  28. };
  29. // for...of 实现的原理就是不断调用Iterator接口
  30. // 通过 for...of 验证接口是否配置成功,如果没有配置成功,object就无法使用 for...of循环
  31. for (let key of obj) {
  32. console.log(key); // 1 2 3 4 5 6
  33. }
  34. }

3.for...of循环

  1. {
  2. // 数组内部实现了iterator接口,所以可以直接使用for...of循环
  3. let arr = ['hello', 'world'];
  4. for (let value of arr) {
  5. console.log(value); // hello world
  6. }
  7. }








ican 26 发布于 超级有温度的代码

1 天前发布

【ES6入门13】:Iterator

  • 前端

  • es6

  • javascript

14 次阅读 · 读完需要 6 分钟



0


es6中,操作某些数据结构(array object map set)时,怎么用一个统一的方法操作,Iterator接口实现了这样的功能

1.Iterator在数组中的应用

  1. {
  2. let arr = ['hello', 'world'];
  3. // 数组内部实现了iterator接口,所以直接调用[Symbol.iterator]()
  4. let map = arr[Symbol.iterator]();
  5. console.log(map.next()); // {value: "hello", done: false}
  6. console.log(map.next()); // {value: "world", done: false}
  7. console.log(map.next()); // {value: undefined, done: true}
  8. // value 表示数组元素,done表示循环是否有下一步状态,true:没有下一步了,false:循环没有结束
  9. }

2.自定义Iterator接口

  1. {
  2. // object没有内置iterator接口,自定义iterator接口,让obj也可以使用for...of
  3. let obj = {
  4. start: [1,2,3],
  5. end: [4,5,6],
  6. // 声明iterator接口方法
  7. [Symbol.iterator]() {
  8. // 先遍历start,再遍历end
  9. let arr = this.start.concat(this.end);
  10. let index = 0;
  11. // 返回next()
  12. return {
  13. next() {
  14. if (index < arr.length) {
  15. return {
  16. value: arr[index++],
  17. done: false
  18. }
  19. } else {
  20. return {
  21. value: arr[index++],
  22. done: true
  23. }
  24. }
  25. }
  26. }
  27. }
  28. };
  29. // for...of 实现的原理就是不断调用Iterator接口
  30. // 通过 for...of 验证接口是否配置成功,如果没有配置成功,object就无法使用 for...of循环
  31. for (let key of obj) {
  32. console.log(key); // 1 2 3 4 5 6
  33. }
  34. }

3.for...of循环

  1. {
  2. // 数组内部实现了iterator接口,所以可以直接使用for...of循环
  3. let arr = ['hello', 'world'];
  4. for (let value of arr) {
  5. console.log(value); // hello world
  6. }
  7. }


你可能感兴趣的



评论

默认排序 时间排序



载入中...

显示更多评论


以上就是ES6中Iterator接口的代码示例讲解的详细内容,更多请关注Gxl网其它相关文章!

人气教程排行