麻豆黑色丝袜jk制服福利网站-麻豆精品传媒视频观看-麻豆精品传媒一二三区在线视频-麻豆精选传媒4区2021-在线视频99-在线视频a

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術(shù)干貨  > 深入探究ES6 for...in

深入探究ES6 for...in

來源:千鋒教育
發(fā)布人:xqq
時間: 2023-11-24 21:21:21 1700832081

一、基礎(chǔ)用法

ES6中的for...in循環(huán)與ES5中的for...in有所區(qū)別。在ES5中,使用for...in循環(huán)來迭代對象的屬性,在迭代時,可以遍歷對象的自有屬性和繼承屬性。在ES6中,使用for...in循環(huán)遍歷對象的屬性時,只遍歷對象的自有屬性,不會遍歷繼承屬性。


    const obj = {a: 1, b: 2, c: 3};
    for (let key in obj) {
      console.log(key); // 'a' 'b' 'c'
      console.log(obj[key]); // 1 2 3
    }

在上面的例子中,使用for...in循環(huán)遍歷了對象obj中的屬性,并打印出了屬性名和屬性值。需要注意的是,在循環(huán)中使用let聲明變量key避免了全局變量的問題。

二、迭代順序

在ES6中,對象中的屬性是有序的,按照從添加到對象中的順序排序。使用for...in循環(huán)會按照這個順序迭代對象的屬性。但是需要注意的是,如果對象的key是字符串,那么它們的遍歷順序是不確定的。


    const obj = {a: 1, b: 2, c: 3};
    console.log(Object.getOwnPropertyNames(obj)); // ['a', 'b', 'c']
    
    const arr = ['a', 'b', 'c'];
    for (let key in arr) {
      console.log(key); // '0' '1' '2'
      console.log(arr[key]); // 'a' 'b' 'c'
    }

在上面的例子中,第一個例子打印了對象的屬性名數(shù)組,按照添加的順序打印了a、b和c。第二個例子循環(huán)遍歷了一個數(shù)組,輸出了數(shù)組的下標和對應(yīng)的元素。

三、遍歷Map和Set

在ES6中,Set和Map是常用的數(shù)據(jù)結(jié)構(gòu)。使用for...in循環(huán)可以迭代它們的值,其遍歷順序與插入順序相同。


    const set = new Set(['a', 'b', 'c']);
    for (let val of set) {
      console.log(val); // 'a' 'b' 'c'
    }
    
    const map = new Map([['a', 1], ['b', 2], ['c', 3]]);
    for (let key of map.keys()) {
      console.log(key); // 'a' 'b' 'c'
    }
    
    for (let val of map.values()) {
      console.log(val); // 1 2 3
    }
    
    for (let entry of map.entries()) {
      console.log(entry); // ['a', 1] ['b', 2] ['c', 3]
      console.log(entry[0]); // 'a' 'b' 'c'
      console.log(entry[1]); // 1 2 3
    }

在上面的例子中,第一個循環(huán)遍歷了一個Set對象,輸出了Set中的元素。第二個循環(huán)遍歷了一個Map對象的key,第三個循環(huán)遍歷了一個Map對象的value,而第四個循環(huán)遍歷了一個Map對象的每一項entry,然后輸出了entry的key和value。

四、使用Symbol.iterator方法

可以在自定義對象上使用Symbol.iterator方法來使其能夠被for...of循環(huán)遍歷。


    const iterableObject = {
        values: [1, 2, 3],
        [Symbol.iterator]() {
            let index = -1;
            return {
                next: () => ({ value: this.values[++index], done: !(index in this.values) })
            };
        }
    };
    
    for (let val of iterableObject) {
      console.log(val); // 1 2 3
    }

在上面的例子中,自定義對象iterableObject中定義了一個values數(shù)組和一個Symbol.iterator方法。在Symbol.iterator方法中返回一個包含next()方法的迭代器對象,每次調(diào)用next()函數(shù)遍歷values數(shù)組中的值。

五、結(jié)語

通過本篇文章,我們深入探究了ES6中for...in循環(huán)的使用方法和注意事項,包括基礎(chǔ)用法、迭代順序、遍歷Set和Map以及使用Symbol.iterator方法。在實際應(yīng)用中,我們可以根據(jù)具體場景靈活使用for...in循環(huán),提高代碼的效率和可維護性。

tags: fileheader
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內(nèi)將與您1V1溝通
免費領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學 138****2860 剛剛成功領(lǐng)取
王同學 131****2015 剛剛成功領(lǐng)取
張同學 133****4652 剛剛成功領(lǐng)取
李同學 135****8607 剛剛成功領(lǐng)取
楊同學 132****5667 剛剛成功領(lǐng)取
岳同學 134****6652 剛剛成功領(lǐng)取
梁同學 157****2950 剛剛成功領(lǐng)取
劉同學 189****1015 剛剛成功領(lǐng)取
張同學 155****4678 剛剛成功領(lǐng)取
鄒同學 139****2907 剛剛成功領(lǐng)取
董同學 138****2867 剛剛成功領(lǐng)取
周同學 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
主站蜘蛛池模板: 国产精自产拍久久久久久蜜| 免费搞基| 精品精品国产高清a级毛片| 日本大片免a费观看在线| 男人天堂官方网站| 久久精品99香蕉国产| 操大逼片| 欧美巨大黑人hd| 日韩欧美国产三级| 国产一精品一av一免费爽爽 | 啊灬啊别停灬用力啊老师在线| 日本三级黄视频| 大学生一级片| 日本一道本| 欧美一级二级三级视频| 中文字幕精品视频在线观| 国产高清一级伦理| 午夜精品久久久久久久久| 国产精品igao视频网| 亚洲剧情在线观看| 八戒在线视频| 国产精品免费_区二区三区观看| 国产一区二区精品久久| 911香蕉视频| 3d无遮挡h肉动漫在线播放| 国产在线精品一区二区中文| 2021日产国产麻豆| 韩国三级hd中文字幕| 免费看国产一级特黄aa大片| 欧美日韩精品一区二区三区不卡| 午夜影院欧美| 免费91麻豆精品国产自产在线观看| 免费毛片在线视频| 男人和女人做爽爽视频| 小婷又紧又深又滑又湿好爽| 天天射天天干天天| 小受被强攻按做到哭男男| 久久一区二区精品| 午夜不卡av免费| 亚洲电影中文字幕| 里番牝教师~淫辱yy608|