深入探究ES6 for…in

一、基礎用法

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


    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循環遍歷了對象obj中的屬性,並打印出了屬性名和屬性值。需要注意的是,在循環中使用let聲明變量key避免了全局變量的問題。

二、迭代順序

在ES6中,對象中的屬性是有序的,按照從添加到對象中的順序排序。使用for…in循環會按照這個順序迭代對象的屬性。但是需要注意的是,如果對象的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'
    }

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

三、遍歷Map和Set

在ES6中,Set和Map是常用的數據結構。使用for…in循環可以迭代它們的值,其遍歷順序與插入順序相同。


    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
    }

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

四、使用Symbol.iterator方法

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


    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數組和一個Symbol.iterator方法。在Symbol.iterator方法中返回一個包含next()方法的迭代器對象,每次調用next()函數遍歷values數組中的值。

五、結語

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

原創文章,作者:TZMUA,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/361032.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
TZMUA的頭像TZMUA
上一篇 2025-02-24 00:34
下一篇 2025-02-24 00:34

相關推薦

  • Python for循環求1到100的積

    Python中的for循環可以方便地遍歷列表、元組、字典等數據類型。本文將以Python for循環求1到100的積為中心,從多個方面進行詳細闡述。 一、for循環語法 Pytho…

    編程 2025-04-29
  • Python使用for循環打印99乘法表用法介紹

    本文介紹如何使用python的for循環語句來打印99乘法表,我們將從需要的基本知識、代碼示例以及一些加強版來詳細講解。 一、基礎知識 在學習如何使用for循環打印99乘法表之前,…

    編程 2025-04-29
  • Python for循環優化

    本文將介紹如何對Python中的for循環進行優化。 一、使用range()代替直接迭代 Python中的for循環本質上是一種迭代操作,可以對列表、元組、集合等數據結構進行遍歷。…

    編程 2025-04-28
  • in和for的用法區別

    對於Python編程中的in和for關鍵詞,我們在實際編碼中很容易混淆。本文將從多個方面詳細闡述它們的用法區別,幫助讀者正確使用in和for。 一、in關鍵詞 in是用來判斷一個元…

    編程 2025-04-28
  • Python遞減for循環代碼的實現

    Python中的for循環可以通過遞減實現,遞減for循環通常用於倒序遍歷列表、字符串等數據結構。在本文中,我們將從多個方面對Python遞減for循環代碼做詳細的闡述,包括實現方…

    編程 2025-04-27
  • Python利用for循環實現三角形的繪製

    Python是一種高級編程語言,也是非常適合初學者學習的一種編程語言。本文將詳細介紹如何利用Python中的for循環來實現三角形的繪製。通過本文的學習,大家可以對Python的基…

    編程 2025-04-27
  • Python for循環items用法介紹

    Python是一種高級語言,具有簡單易學,代碼量少,語法清晰的特點。其中for循環是Python中最常見的循環語句之一,而for循環中的items更是讓我們又愛又恨的語法。下面將從…

    編程 2025-04-27
  • Python中for循環遍歷列表

    本文將全方位詳細介紹Python中for循環遍歷列表的方法和技巧,幫助您更加深入理解並靈活運用Python中的for循環。 一、for循環遍歷列表的基礎用法 在Python中使用f…

    編程 2025-04-27
  • Python中for i in range()函數的用法

    本文將詳細闡述Python中for i in range函數的用法。對於初學者來說,這是學習Python編程的基礎之一。 一、range()函數與for循環 Python中的for…

    編程 2025-04-27
  • 深入解析Vue3 defineExpose

    Vue 3在開發過程中引入了新的API `defineExpose`。在以前的版本中,我們經常使用 `$attrs` 和` $listeners` 實現父組件與子組件之間的通信,但…

    編程 2025-04-25

發表回復

登錄後才能評論