溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

ES6中Iterator接口怎么用

發布時間:2020-12-08 13:56:47 來源:億速云 閱讀:178 作者:小新 欄目:web開發

這篇文章主要介紹了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
    }
}

感謝你能夠認真閱讀完這篇文章,希望小編分享ES6中Iterator接口怎么用內容對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,遇到問題就找億速云,詳細的解決方法等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女