遍历器的基本实现

遍历器想必大家都知道,今天自己实现了一个简单的遍历器,欢迎大家一起交流探讨。

基本实现

const obj = {0: 'a', 1: 'b',2: 'c', length:3};
obj[Symbol.iterator] = function () {
	let index = 0;
	return {
		next: () => {
			return {
				value: this[index],
				done: index++ === this.length
			}
		}
	}
}
console.log([...obj]) // ['a', 'b', 'c']

观察上边的代码我们发现, 遍历器最终返回的是一个包含next方法的对象,并且next方法返回一个包含 value和done的对象。有没有觉得和generator函数很像。那接下来我们就用generator函数把刚才的遍历器重新实现一遍。

通过generator函数实现

const obj = {0: 'a', 1: 'b',2: 'c', length:3};
obj[Symbol.iterator] = function * () {
	let index = 0;
	while( index !== this.length) {
		yield this[index++]
	}
	
}
console.log([...obj]) // ['a', 'b', 'c']

有没有发现使用generator函数更简单了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
雪山凌狐教程出品,文件遍来袭,希望通过源码的分享能跟大家一起学习文件的遍功能,内涵绝对干货内容和套路可以直接套用! 为了避免不使用线程时界面卡顿,调用了精易模块5.28的线程功能,你不喜欢可以自己去掉或者用上自己写的多线程代码都可。这个关系不大。 其他部分纯源码不涉及其他模块。 软件功能: 1. 首先设定一个要遍的文件夹,可以设置要遍文件的后缀名或者不设置,可以选择是否遍子目录或者只是根目录,进行所有文件的遍并输出找到的文件的文件名,文件完整路径,修改时间,文件大小到超级列表框。 2. 遍完成后,可以在搜索框输入内容进行即时搜索,请注意是即时的。 3. 可以点击清空清空列表框内容。 4. 可以自动保存和读取配置。(该部分用了模块的批量保存命令,你也可以手动保存) 源代码亮点: 1. 线程调用,界面不卡顿(可以自己改了删掉或者用自己的多线程代码) 2. 新建了一个程序集叫做“程序集_遍”,里面的“遍文件”函数可以脱离该源码使用到你任何的程序中,可直接接入性非常高,只需要传入参数即可。 3. 主窗口的函数中有一个函数叫做“时间格式化”,也可以直接脱离该源码直接使用。 4. 当搜索框内容被改变时,如何进行即时搜索并再次显示出来?源码中是一个很好的例子,值得学习。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值