您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

ES6中Iterator接口的代码示例讲解

2024/3/31 23:33:55发布20次查看
本篇文章给大家带来的内容是关于es6中iterator接口的代码示例讲解,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
es6中,操作某些数据结构(array object map set)时,怎么用一个统一的方法操作,iterator接口实现了这样的功能
1.iterator在数组中的应用
{    let arr = ['hello', 'world'];    // 数组内部实现了iterator接口,所以直接调用[symbol.iterator]()    let map = arr[symbol.iterator]();    console.log(map.next()); // {value: hello, done: false}    console.log(map.next()); // {value: world, done: false}    console.log(map.next()); // {value: undefined, done: true}    // value 表示数组元素,done表示循环是否有下一步状态,true:没有下一步了,false:循环没有结束}

2.自定义iterator接口
{    // object没有内置iterator接口,自定义iterator接口,让obj也可以使用for...of    let obj = {        start: [1,2,3],        end: [4,5,6],        // 声明iterator接口方法        [symbol.iterator]() {            // 先遍历start,再遍历end            let arr = this.start.concat(this.end);            let index = 0;            // 返回next()            return {                next() {                    if (index < arr.length) {                        return {                            value: arr[index++],                            done: false                        }                    } else {                        return {                            value: arr[index++],                            done: true                        }                    }                }            }        }    };    // for...of 实现的原理就是不断调用iterator接口    // 通过 for...of 验证接口是否配置成功,如果没有配置成功,object就无法使用 for...of循环    for (let key of obj) {        console.log(key); // 1 2 3 4 5 6    }}

3.for...of循环
{    // 数组内部实现了iterator接口,所以可以直接使用for...of循环    let arr = ['hello', 'world'];    for (let value of arr) {        console.log(value); // hello world    }}

专栏
超级有温度的代码
文章详情
ican                                                                                                26                                                                                                发布于                                                超级有温度的代码                                                                                                                                                                                                                                                                                                                                                          
                                                   1 天前发布                                                                                            
【es6入门13】:iterator
前端
es6
javascript
                                               14 次阅读                                                 ·                                                 读完需要 6 分钟
0
es6中,操作某些数据结构(array object map set)时,怎么用一个统一的方法操作,iterator接口实现了这样的功能
1.iterator在数组中的应用
{    let arr = ['hello', 'world'];    // 数组内部实现了iterator接口,所以直接调用[symbol.iterator]()    let map = arr[symbol.iterator]();    console.log(map.next()); // {value: hello, done: false}    console.log(map.next()); // {value: world, done: false}    console.log(map.next()); // {value: undefined, done: true}    // value 表示数组元素,done表示循环是否有下一步状态,true:没有下一步了,false:循环没有结束}

2.自定义iterator接口
{    // object没有内置iterator接口,自定义iterator接口,让obj也可以使用for...of    let obj = {        start: [1,2,3],        end: [4,5,6],        // 声明iterator接口方法        [symbol.iterator]() {            // 先遍历start,再遍历end            let arr = this.start.concat(this.end);            let index = 0;            // 返回next()            return {                next() {                    if (index < arr.length) {                        return {                            value: arr[index++],                            done: false                        }                    } else {                        return {                            value: arr[index++],                            done: true                        }                    }                }            }        }    };    // for...of 实现的原理就是不断调用iterator接口    // 通过 for...of 验证接口是否配置成功,如果没有配置成功,object就无法使用 for...of循环    for (let key of obj) {        console.log(key); // 1 2 3 4 5 6    }}

3.for...of循环
{    // 数组内部实现了iterator接口,所以可以直接使用for...of循环    let arr = ['hello', 'world'];    for (let value of arr) {        console.log(value); // hello world    }}

举报
你可能感兴趣的
评论                                                    
默认排序                        时间排序
载入中...
显示更多评论
以上就是es6中iterator接口的代码示例讲解的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product