迭代器模式

迭代器模式

1. 介绍

  • 顺序访问一个集合
  • 使用者无需知道集合的北部结构(封装)

2. UML 演示

在这里插入图片描述

3. 代码演示

class Iterator {
  constructor(container) {
    this.list = container.list
    this.index = 0
  }

  next() {
    if (this.hasNext()) {
      return this.list[this.index++]
    }
    return null
  }
  hasNext() {
    if (this.index >= this.list.length) {
      return false
    }
    return true
  }
}

class Container {
  constructor(list) {
    this.list = list
  }
  //生成遍历器
  getIterator() {
    return new Iterator(this)
  }
}

//测试
var arr = [1, 2, 3, 4, 5, 6]
let container = new Container(arr)
let iterator = container.getIterator()
while (iterator.hasNext()) {
  console.log(iterator.next())
}

4. 场景

4.1 jQuery each

//一个方法遍历三种对象
function each(data) {
  var $data = $(data) //生成迭代器
  $data.each(function(key, p) {
    console.log(key, p)
  })
}
//测试
each(arr)
each(nodeList)
each($p)

4.2 ES6 Iterator

  • arraymap 等数据类型都有[Symbol.iterator]属性

  • 属性值是函数,执行函数返回一个迭代器

  • 这个迭代器就有 next 方法可顺序迭代子元素

  • 可运行 Array.prototype[Symbol.iterator]来测试

    function each(data) {
      //生成遍历器
      let iterator = data[Symbol.iterator]()
      //有数据时返回{value:1,done:false}
      //console.log(iterator.next())
      //console.log(iterator.next())
      //console.log(iterator.next())
      //console.log(iterator.next())
      //没有数据时返回{value: undefined, done: true}
      //console.log(iterator.next())
      //console.log(iterator.next())
      //console.log(iterator.next())
      let item = {
        done: false
      }
      while (!item.done) {
        iterator.next()
        if (!item.done) {
          console.log(item.value)
        }
      }
    }
    
    //测试
    let arr = [1, 2, 3, 4]
    let nodeList = document.getElementsByTagName('p')
    let m = new Map()
    m.set('a', 100)
    m.set('b', 200)
    
    function each(data) {
      for (let item of data) {
        console.log(item)
      }
    }
    

4.3 Generator

  • 只要返回的数据符合 Iterator 接口的要求即可使用 Iterator 语法

5. 设计原则

  • 迭代器对象和目标对象分离
  • 迭代器将使用者与目标对象隔离开
  • 符合开放封闭原则
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值