ES6_08_Iterator遍历器

Iterator遍历器:

概念:

iterator是一种接口机制,为各种不同的数据结构提供统一的访问机制

作用:

1、为各种数据结构,提供一个统一的、简便的访问接口;
2、使得数据结构的成员能够按某种次序排列
3、ES6创造了一种新的遍历命令for...of循环,Iterator接口主要供for...of消费。

工作原理:

- 创建一个指针对象(遍历器对象),指向数据结构的起始位置。
- 第一次调用next方法,指针自动指向数据结构的第一个成员
- 接下来不断调用next方法,指针会一直往后移动,直到指向最后一个成员
- 每调用next方法返回的是一个包含value和done的对象,{value: 当前成员的值,done: 布尔值}
* value表示当前成员的值,done对应的布尔值表示当前的数据的结构是否遍历结束。
* 当遍历结束的时候返回的value值是undefined,done值为false
原生具备iterator接口的数据(可用for of遍历)
1、Array
2、arguments
3、set容器
4、map容器
5、String

...

举例说明:

//模拟指针对象(遍历器对象)
function myIterator() {
        let nextIndex = 0; //记录指针的位置
        return { //遍历器对象
            next:function () {
                return nextIndex <arr.length?{value:arr[nextIndex++], done: false}:{value:undefined,done:true}
            }
        }
    }
    //准备一个数据
    let arr = [1,4,65,'abc'];
    let iteratorObj = myIterator(arr);
    console.log(iteratorObj.next());
    console.log(iteratorObj.next());
    console.log(iteratorObj.next());
    console.log(iteratorObj.next());
    console.log(iteratorObj.next());
    console.log(iteratorObj.next());

 

//将iterator接口部署到指定的数据类型上,可以使用for of去循环遍历
//数组,字符串,arguments,set容器,map容器
for (let i of arr){
        console.log(i)
    }

    let str = 'abcdefg';
    for(let i of str){
        console.log(i);
    }
    function fun() {
        for (let i of arguments){
            console.log(i);
        }
    }
    fun(1,4,5,'abc');

    let obj = {username:'kobe', age:39};
   // for(let i of obj){
  //      console.log(i)
   // }

 

 
 
//等同于在指定的数据内结构上部署了iterator接口
//当使用for of去遍历某一个数据结构的时候,首先去找Symbol.iterator,找到了就去遍历,没有找到的话就不能遍历 xxx is not iterable
let targetData = {
        [Symbol.iterator]: function () {
            let nextIndex = 0; //记录指针的位置
            return { //遍历器对象
                next: function () {
                    return nextIndex < this.length ? {value: this[nextIndex++], done: false} : {
                        value: undefined,
                        done: true
                    }
                }
            }
        }
    }

 

//使用三点运算符,解构赋值,默认去调用iterator接口
 let arr2 = [1, 6];
 let arr3 = [2,3,4,5];
 arr2 = [1,...arr3,6]
 console.log(arr2)
 let [a,b] = arr2;
 console.log(a,b)
 //得到1和2

 

 
 
 

 

转载于:https://www.cnblogs.com/sunjiaojiao/p/11149487.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值