日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

細說JS數組遍歷的一些細節及實現

瀏覽:237日期:2022-06-09 14:43:43
目錄
  • 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數組遍歷的一些細節及實現的文章就介紹到這了,更多相關JS數組遍歷內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!

    標簽: JavaScript
    相關文章:
    日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
    黄色av日韩| 综合一区二区三区| 亚洲色图网站| 丝袜亚洲另类欧美| 久久av一区二区三区| 爽爽淫人综合网网站| 蜜桃视频一区二区三区在线观看| 欧美综合国产| 亚洲精品看片| 欧美日韩伊人| 欧美精品不卡| 亚洲黄色网址| 亚洲成人va| 99精品99| 日韩精选在线| 久久久精品区| 91精品蜜臀一区二区三区在线| 在线观看精品| 欧美日韩国产免费观看视频| 日本 国产 欧美色综合| 人人爱人人干婷婷丁香亚洲| 久久av国产紧身裤| 亚洲国产成人二区| 激情欧美丁香| 中文字幕免费精品| 国产精品亚洲人成在99www | 久久精品91| 午夜久久美女| 日本va欧美va瓶| 精品久久福利| 电影91久久久| 久久精品1区| 最近国产精品视频| 欧美aaaaaa午夜精品| 午夜精品成人av| 最新亚洲激情| 国产精品一区二区三区美女 | 给我免费播放日韩视频| 国内亚洲精品| 亚洲免费福利一区| 欧美黑人做爰爽爽爽| 成人精品视频| 国产日韩综合| 无码日韩精品一区二区免费| 国产毛片久久久| 欧美国产偷国产精品三区| 久久麻豆精品| 一区二区电影在线观看| 国产精品对白| 久久视频精品| 欧美日韩1区| 亚洲最新无码中文字幕久久| 中日韩男男gay无套| 久久国内精品视频| 日韩一区二区中文| 亚洲啊v在线免费视频| 久久一区精品| 一区在线免费观看| 日韩在线黄色| 国产精品久久久久久久久妇女| 婷婷综合网站| 国产精品一区高清| 免费精品国产的网站免费观看| 亚州国产精品| 神马久久午夜| 少妇高潮一区二区三区99| 日韩精品1区| 婷婷五月色综合香五月| a天堂资源在线| 日韩一区二区三区四区五区| 精品久久久亚洲| 模特精品在线| 岛国av在线网站| 麻豆久久精品| 欧美久久天堂| 国产精品亚洲二区| 亚洲综合电影一区二区三区| 国产极品久久久久久久久波多结野| 99久久久久国产精品| 日本电影久久久| 久久影视一区| 国产精品片aa在线观看| 欧美日韩精品免费观看视频完整| 久久午夜影院| 久久国产乱子精品免费女| 日韩高清成人| 美女视频黄久久| 老司机精品久久| 神马久久午夜| 亚洲精品乱码久久久久久蜜桃麻豆| 欧美日韩精品免费观看视欧美高清免费大片 | 国产日韩1区| 一区在线免费| a日韩av网址| 免费在线亚洲欧美| 亚洲精品无播放器在线播放| 黄色av一区| 999国产精品永久免费视频app| 日韩av不卡一区二区| 亚洲专区欧美专区| 免费观看不卡av| 日韩欧美二区| 精品少妇av| 国产精品成人**免费视频 | 国产毛片久久久| 亚洲久草在线| 日韩中文字幕一区二区三区| 久久久久久久久久久9不雅视频| 精品一区二区男人吃奶| 日韩激情一二三区| 国产精品毛片在线看| 国产va免费精品观看精品视频| 久久精品99国产精品日本| 中文无码日韩欧| 亚洲欧美日韩国产| 国产综合视频| 精品成人免费一区二区在线播放| 国产成人精品一区二区三区视频| 国产欧美日韩精品一区二区免费| 日日夜夜免费精品视频| 日韩一区精品字幕| 午夜在线一区| 99视频一区| 久久中文视频| 久久精品主播| 久久久五月天| 最新中文字幕在线播放| 91欧美在线| 97精品在线| 日韩欧美午夜| 色婷婷久久久| 99精品综合| 影音先锋国产精品| 亚洲成人一区| 国产一级久久| 青草综合视频| 国产乱人伦精品一区| 国产欧美在线| 国产精品久久久免费| 国产毛片精品久久| 精品中文字幕一区二区三区四区| 91福利精品在线观看| 国产精品羞羞答答在线观看| 国产精品一线天粉嫩av| 精品国产一区二区三区噜噜噜| 国产不卡精品在线| 久久久国产亚洲精品| 免费欧美一区| 中文字幕免费精品| 国产精品对白| 日本在线啊啊| 欧美午夜不卡影院在线观看完整版免费 | 日韩国产欧美在线播放| 国产亚洲欧美日韩精品一区二区三区| 亚洲aⅴ网站| 国产精品久久国产愉拍| 97精品一区| 亚洲美洲欧洲综合国产一区 | 欧美久久精品一级c片| 蜜桃视频一区二区三区在线观看| 日本午夜精品久久久久| 狠狠久久伊人中文字幕| 久久久久久久久久久妇女| 美女久久网站| 国产精品一区二区精品| 精品成人免费一区二区在线播放| 亚洲中午字幕| 麻豆精品一区二区综合av| 久久99偷拍| 精品成人免费一区二区在线播放| 午夜一级久久| 国产精品亚洲二区| 亚洲www啪成人一区二区| 蜜芽一区二区三区| 欧美国产日韩电影| 久久国产免费| 亚洲精品伊人| 久久精品国产成人一区二区三区| 久久精品亚洲欧美日韩精品中文字幕| 亚洲欧美日韩在线观看a三区 | bbw在线视频| 日本欧洲一区二区| 国产精品videossex久久发布| 国产一区调教| 亚洲一区国产| 精品网站999| 欧美专区18| 中文在线免费视频| 亚洲97av| 99久久久久国产精品| 欧美亚洲tv| 今天的高清视频免费播放成人| 日韩成人一级| 久久久成人网| 欧美日韩夜夜| 一本大道色婷婷在线| 日韩欧美激情| 成人va天堂| 国产日韩三级| 免费日韩一区二区|