iterator和generator

iterator和generator

iterator

es6: let/const ...展开 

iterator和generator_第1张图片

迭代器

是一种机制,比如在控制台输出Iterator是没有这个类的,为不同的数据结构提供迭代循环的机制。

迭代器对象:具备next方法,next能够对你指定的数据进行迭代循环,next依次取出集合中的每一项。第一次执行next拿第一项,第二次执行next拿第二项……

iterator和generator_第2张图片

内部实现

iterator和generator_第3张图片

具备Symbol.iterator

iterator和generator_第4张图片

JS - iterator(迭代器)

内部实现

iterator和generator_第5张图片

ps.done为true结束那个循环,为true时那个值也不要了

obj={name:'angela',age:18,sex:'female'}
Object.prototype[Symbol.iterator]=function(){
    let self=this;
    let keys=Object.keys(self)
    let index=0;
    return {
        next(){
            // 边界校验
            if(index>=keys.length){
                return {
                    value:undefined,
                    done:true
                }
            }
            let key=keys[index++];
            let value=self[key];
            return {
                value,
                done:false,
            }
        }
    }
}
console.dir(obj)
for(let value of obj){
    console.log(value)
}

JS中的循环

new Array(99999999)  // 这个时候还是一个稀疏数组

稀疏数组是不能使用for of循环的,使用fill填充

iterator和generator_第6张图片

iterator和generator_第7张图片iterator和generator_第8张图片

generator生成器

生成了一个具有迭代器规范的对象(迭代器对象),

iterator和generator_第9张图片

返回一个迭代器对象

通过next&yield控制函数体中的代码一步步执行

每次next得到的value就是每次执行到yield(或return)后的值

每次next传值作为上次yield的返回结果

yield* 进入生成器执行

串行

终极解决方案:递归实现

初级版

iterator和generator_第10张图片

判断是否是promise

iterator和generator_第11张图片


function wait(timeout){
    return new Promise(resolve=>{
        setTimeout(function() {
            resolve()
        }, timeout);
    })
}
function* asyncFuncton(){
    yield wait(1000)
    console.log('第1秒')
    yield wait(2000)
    console.log('第2秒')
    yield wait(3000)
    console.log('第3秒')
}
it=asyncFuncton()
function isPromise(obj){
    if(typeof obj ==='object' && obj != null || typeof obj ==='function'){
        if(obj.then && typeof obj.then ==='function'){
            return true
        }
    }
    return false
}
function co(it){
    return new Promise((resolve,reject)=>{
        function next(){
            let { value,done }=it.next()
            console.log(value,done)
            if(done) return resolve();
            // 处理value为非promise的情况
            if(!isPromise(value)) value=Promise.resolve(value)
            value.then(()=>{
                next()
            }).catch((e)=>reject(e))
        }
        next()
    })
    
}
co(it);

完善版:

iterator和generator_第12张图片

你可能感兴趣的:(javascript,前端,vue.js)