一、迭代器模式在Redux源码中的使用
data:image/s3,"s3://crabby-images/c0f61/c0f6181791a72fa92fcd8dc4925543380d0e71fb" alt=""
二、迭代器模式在Koa2源码中的使用
data:image/s3,"s3://crabby-images/1c6d7/1c6d7d32c393ef6178b3c869a4947252b2f18ffe" alt=""
场景一、二都是利用迭代器模式,依次调用中间件,从而实现各个框架中的洋葱模型。
三、 迭代器模式在Webpack源码中的使用
data:image/s3,"s3://crabby-images/303f3/303f3b62a05885f975ea14be6804e4ea7290e03b" alt=""
简单解释下,实参modulesData是从入口文件出发,通过递归分析得到的,所有依赖文件的集合,其格式如下:
data:image/s3,"s3://crabby-images/3139a/3139a3b65539f6ee2ab200adcd288c77e9f5b5f8" alt=""
四、迭代器模式在es6中是使用
es6中之所以可以实现数组的扩展运算符以及for..of循环,是因为其内部定义了一个[Symbol.iterator]属性,这个属性的value是一个函数(迭代函数),其大致实现如下:
data:image/s3,"s3://crabby-images/c5c25/c5c25da1658f124e170f2d47b477356871cb41e1" alt=""
五、其他
这里只是举几个简单的例子,其实迭代器模式在前端领域还有非常广泛的应用,比如vue-router中各个导航守卫的依次调用、async&await函数的实现等。
网友评论