javascript迭代器怎么实现

本篇内容主要讲解“javascript迭代器怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“javascript迭代器怎么实现”吧!

为涿鹿等地区用户提供了全套网页设计制作服务,及涿鹿网站建设行业解决方案。主营业务为成都网站设计、成都网站建设、涿鹿网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!

在javascript中,迭代器是一种特殊对象,它具有一些专门为迭代过程设计的专有接口,所有的迭代器对象都有一个next()方法,每次调用都返回一个结果对象。迭代器会保存一个内部指针,用来指向当前集合中值的位置。

本教程操作环境:windows7系统、javascript1.8.5版、Dell G3电脑。

一、迭代器的定义:

迭代器是一种特殊对象,它具有一些专门为迭代过程设计的专有接口,所有的迭代器对象都有一个next()方法,每次调用都返回一个结果对象。结果对象有两个属性:一个是value,表示下一个将要返回的值;另一个是done,它是一个布尔类型的值,当没有更多可返回数据时返回true。迭代器还会保存一个内部指针,用来指向当前集合中值的位置,每调用一次next()方法,都会返回下一个可用的值

如果在最后一个值返回后再调用next()方法,那么返回的对象中属性done的值为true,属性value则包含迭代器最终返回的值,这个返回值不是数据集的一部分,它与函数的返回值类似,是函数调用过程中最后一次给调用者传递信息的方法,如果没有相关数据则返回undefined

二、为何会出现迭代器?

背景前提:

我相信你一定用过for循环,并且也有过空指针引用的问题:比如数组长度只有5,但是你的索引却跑到了6。逻辑稍微失误,就导致程序不能正常运行。

迭代器想要解决的问题是:

解决、或减少使用类似for循环过程中,访问变量集合的中出错的问题。比如:空指针引用

举个栗子:

我们使用for循环遍历集合时,容易出错,但是我们使用类似forEach的话,就会减少空指针引用的问题。

array.forEach(element => {
	// 此时可以不用i来操作集合了。            
});

三、用js实现一个简单的迭代器

function myIterator(list) {
    let i = 0;
    return {
        next: function() {
            let done = (i >= list.length);
            let value = !done ? list[i++] : undefined;
            return {
                done: done,
                value: value
            };
        }
    };
}

由函数定义可以看出:

  • 函数返回值是个对象,对象中,key为next、value为函数;

  • 每调用一次next(),i+1,同时返回一个对象,对象就是集合的元素;

到此,相信大家对“javascript迭代器怎么实现”有了更深的了解,不妨来实际操作一番吧!这里是创新互联网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!


文章标题:javascript迭代器怎么实现
URL分享:http://scyanting.com/article/gppooi.html