中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

JS數組遍歷的細節以及實現記錄

發布時間:2023-06-19 10:04:55 來源:億速云 閱讀:101 作者:栢白 欄目:開發技術

本篇文章和大家了解一下JS數組遍歷的細節以及實現記錄。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有所幫助。

目錄
  • 1. 數組空位問題

    • 1.1 空位判斷

    • 1.2 剛列舉了數組的一些操作會對空位進行跳過,但其實,它們在處理上也還是存在一些差異的

  • 2. 是否修改原數組

    • 3. 附一下數組遍歷的幾種方法

      • 3.1 索引訪問

      • 3.2 for ... of

      • 3.3 forEach

      • 3.4 for ... in

      • 3.5 map、filter、reduce

    1. 數組空位問題

    數組空位是什么,它是數組內某個元素沒有任何值,這種現象稱為空位現象,我們在使用Array()去構造一個數組時,如果只傳入一個參數,數組里面的元素項就會出現空位現象,它其實是沒有任何元素的,下面是幾個會創建空位的典型例子:

    let arr = Array(5) // <5 empty items>
    let res = arr.map(e => e + 1) // <5 empty items>
    let a = [,,]; // <2 empty items>

    ES5 中的數組方法包括:map、filter、forEach、reduce,還有 for ... in 等語法,這些方法執行的時候遇到空位,會直接跳過。

    // ES5 及以前,不會處理空位
    const a = Array(5);
    console.log(a) // [ <5 empty items> ]
    console.log(a.map(_ => 1)) // 無效,[ <5 empty items> ]
    // console.log(a.reduce((p, c)=> p+c)) // 報錯
    console.log(a.filter(x => true)) // []
    a.forEach(e => {
      console.log(e);
    }) // 無任何輸出
    console.log(a+'') // ,,,,
    console.log(a.indexOf(undefined)) // -1
    console.log(a.lastIndexOf(undefined)) // -1
    for (let k in a) {
      console.log(k) // 無任何輸出
    }

    ES5中將空位視為undefined的有:join(),toString()

    [,'a','b',undefined,null].join("@") // '@a@b@@'
    [,'a','b',undefined,null].toString() // ',a,b,,'

    ES6,一些操作會將數組空位視為undefined來處理。比如下面的一些操作

    console.log([...a]) // [ undefined x 5 ]
    console.log(Array.from(a)) // [ undefined x 5 ]
    console.log(a.includes(undefined)) // true
    console.log(a.find(x => x === undefined)) // undefined
    console.log(a.findIndex(x => x === undefined)) // 0
    // for of 循環取值
    for (let k of a) {
      console.log(k) // 輸出5個undefined
    }

    1.1 空位判斷

    我們可以使用in運算符來判斷數組某個位置是否存在空位

    let arr = Array(3) console.log(0 in arr) // false

    如上述所示,使用in運算符,判斷索引為0的位置是否為空位,遇到數組空位會返回false
    這里需要注意的是所謂的空位是沒有任何值的,undefined、null它們都不屬于空位,下面來判斷一下。

    let arr = [undefined, null];
    console.log(0 in arr) // true
    console.log(1 in arr) // true

    驗證了undefined、null所在的位置它不是空位

    1.2 剛列舉了數組的一些操作會對空位進行跳過,但其實,它們在處理上也還是存在一些差異的

    比如:forEach、filter、some與every等在遇到空位時,會直接跳過它,不會保留它的值, 而map則會保留空位
    我們來看下例子:

    [,1,2].forEach((x,i) => { console.log(i); }) // 這里只會輸出1 2
    [,1,2].filter((x,i) => { return x > 0; }) // 這里也只會輸出[1, 2]
    [,1,2].map((x) => { return x > 0; }) // 這里會輸出[空, true, true],它保留了空位

    其余的可以自行測試看看結果

    2. 是否修改原數組

    請看以下代碼,遍歷過程中,試圖修改遍歷的每一項。

    const arr = [1, 2, 3]
    let res = arr.filter(item => {
      item++
      return item >= 3
    })
    console.log(arr) // [ 1, 2, 3 ]
    console.log(res) // [ 2, 3 ]

    filter 里的 item 自增了,所以最后有兩項符合過濾規則,但是原數組并沒有變。這說明這里的 item 只是原數組項的一個值拷貝,數組遍歷是按值傳遞的。
    再看一段代碼,這次我們遍歷引用數據類型的數組。

    const brr = [
      {count: 1},
      {count: 1},
      {count: 1}
    ]
    const res2 = brr.map(item => {
      item.count++
      return item.count
    })
    console.log(brr) // [ { count: 2 }, { count: 2 }, { count: 2 } ]
    console.log(res2) // [ 2, 2, 2 ]

    這里的修改改變了原數組,那之前說的按值傳遞有問題?其實還沒問題的,數組函數方法說到底也是一個函數,JS 的函數總是按值傳遞的:

    基本數據類型(包含變量、函數參數等)存儲在棧(stack)中,傳遞參數會復制一份值
    引用數據類型的引用(指針)存儲在棧中,指向的值存儲在堆(heap)中,傳遞參數會復制一份對象的引用地址,復制的引用地址和原引用地址指向堆中同一個對象(因此修改參數,也修改了原對象)

    3. 附一下數組遍歷的幾種方法

    3.1 索引訪問

    const arr = [1, 2, 3]
    for (let i = 0; i < arr.length; i++) {
      console.log(arr[i])
    }

    3.2 for ... of

    const arr = [1, 2, 3]
    for (let e of arr) {
      console.log(e)
    }

    3.3 forEach

    注意:return 和 break 無法中斷遍歷。

    • return 可以跳過本次遍歷,但剩余元素仍然會繼續遍歷下去。

    • break 只能中斷 for 和 while 循環,forEach 函數中使用會報錯

    const arr = [1, 2, 3]
    arr.forEach((e, i, a) => {
    console.log(e)
    })

    3.4 for ... in

    `for ... in` 是用來遍歷對象(plain object)的,也可以用來遍歷數組,但不建議。

    const arr = [1, 2, 3]
    for (let i in arr) {
      console.log(arr[i])
    }

    3.5 map、filter、reduce

    這三類都是為了對數組進行一個操作,然后得到目標結果的數組方法,從功能和語義上來講,和 forEach 有區別的,不建議混用,尤其是 map 和 forEach。但是也能對數組進行遍歷,詳細可參考MDN。

    以上就是JS數組遍歷的細節以及實現記錄的簡略介紹,當然詳細使用上面的不同還得要大家自己使用過才領會。如果想了解更多,歡迎關注億速云行業資訊頻道哦!

    向AI問一下細節

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

    js
    AI

    桐庐县| 蒲江县| 米脂县| 鲁甸县| 成武县| 九寨沟县| 上犹县| 沅陵县| 嘉善县| 涡阳县| 攀枝花市| 道真| 隆回县| 米脂县| 昭苏县| 页游| 道真| 长葛市| 东港市| 华池县| 扶风县| 常德市| 平乡县| 岳阳市| 墨竹工卡县| 洱源县| 罗源县| 南部县| 松江区| 赤水市| 和田县| 廊坊市| 盐山县| 鄂尔多斯市| 湘乡市| 白玉县| 孟村| 清水河县| 赤壁市| 蚌埠市| 东城区|