ES6——遍历器Iterator && for of循环

本文详细介绍了ES6中的Iterator遍历器接口,包括如何模拟实现遍历器接口、Symbol.iterator的使用,以及在不同场景下如何调用Iterator接口。此外,还探讨了for...of循环的特性,与for...in的区别,以及在Set和Map结构中的应用。
摘要由CSDN通过智能技术生成

一、Iterator 遍历器

进行指针移位,遍历数据

js原有的表示“集合”的数据结构,主要是数组(Array)和对象(Object),ES6 又添加了Map和Set。

Iterator是一种机制。它是一种接口,为各种不同的数据结构提供统一的访问机制。任何数据结构只要部署 Iterator 接口,就可以完成遍历操作(即依次处理该数据结构的所有成员

1.模拟遍历器接口实现

    //自己模拟遍历器接口实现
    function makeInterator(array){
   
        let startIndex=0;
        return{
   
            next: function () {
   
                return startIndex<array.length?{
   value:array[startIndex++],done:false}:
                {
   value:undefined,done:true};
            }
        }
    }
    let inter=makeInterator([1,2,3,4]);
    console.log(inter.next());
    console.log(inter.next());
    console.log(inter.next());
    console.log(inter.next());
    console.log(inter.next());

在这里插入图片描述

2.遍历器接口 Symbol.iterator

Iterator 接口的目的,就是为所有数据结构,提供了一种统一的访问机制,即for…of循环。
当使用for…of循环遍历某种数据结构时,该循环会自动去寻找 Iterator 接口

默认的 Iterator 接口部署在数据结构的Symbol.iterator属性,或者说,一个数据结构只要具有Symbol.iterator属性,就可以认为是“可遍历的”

给object部署Symbol.iterator

在这里插入图片描述
object不存在遍历器接口,需要部署

    let obj={
   
        [Symbol.iterator]:function(){
   
            return{
   
                next: function () {
   
                    return{
   value:1,done:false};
                }
            }
        
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

致可乐

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值