亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術(shù)文章
文章詳情頁

javascript - js中數(shù)組的undefined為什么不會被遍歷

瀏覽:133日期:2023-03-17 15:58:19

問題描述

問題描述并不全面

我的問題是,當(dāng)我的數(shù)組是如下定義的時候:

let a = [undefined, undefined]a[9] = 1console.log(a)//[undefined, undefined, undefined × 7, 1]

這里自動生成的undefined與我定義的有什么區(qū)別嗎?

為什么我用自帶遍歷的時候也不會遍歷到他們?

a.forEach(it => console.log(it)) // 也只會有三個結(jié)果

問題解答

回答1:

因為你定義的是一個稀疏數(shù)組(sparse array,數(shù)組長度比數(shù)組元素個數(shù)大的數(shù)組). 可以用in檢測它的數(shù)組元素是否存在:

’0’ in a // true,索引存在.’1’ in a // true’2’ in a // false,索引不存在’9’ in a // true

forEach 只會遍歷原本那些索引存在的元素.

回答2:

這里自動生成的undefined與我定義的有什么區(qū)別嗎?

這是數(shù)組的一個陷阱,此 undefined 非彼 undefined。自動生成的叫“empty slots”,恰好 chrome 對它顯示 undefined 而已。你也可以看到,真正的 undefined 是一個個輸出來的,empty slots 是輸出“undefined × 7”這樣的字樣。

forEach, map 之類的都會跳過 empty slots。解決方法可以參考

console.log(Array.from(a))回答3:

因為forEach就是這么寫的,自帶的forEach遇到undefined會continue你可以自己寫一個不跳過的版本

回答4:

你可以換一個角度想這個問題:var a = [1,2,3,4]delete a[0]console.log(a)//[undefined × 1, 2, 3, 4]a.length//4a.forEach(it=>console.log(it))// 2 3 4回到問題上,forEach封裝的時候,會跳過這個“undefined”,你可以重寫一下這個方法,無論是什么樣子的值,應(yīng)該都是可以正常打印的

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 亚洲成人一级 | 真人视频一级毛片 | 亚洲色大成网站www久久九九 | 国产成人91一区二区三区 | 天天噜噜色| 国产高清在线精品免费不卡 | 青草免费视频 | 97久久久久国产精品嫩草影院 | 91社区在线观看 | 久久精品人 | 欧美一区二区三区四区在线观看 | 国产三级在线视频观看 | 国产微拍精品 | seba51久久精品 | 亚洲 欧美 国产另类首页 | 国产精品乱 | 欧美一级性 | 激情九月婷婷 | 日韩精品视频免费网址 | 亚洲欧美日韩在线播放 | 拍真实国产伦偷精品 | 久久精品最新免费国产成人 | 一本一本久久a久久精品综合麻豆 | 一级中国毛片 | 尤物在线免费视频 | 欧美成人手机在线视频 | 日本人伦一区二区三区 | 欧美在线黄| 国产日韩欧美一区二区 | 免费一级毛片不卡在线播放 | 中文字幕2022永久在线 | 久久久久777777人人人视频 | 成年偏黄网站站免费 | 黄页网站 播放器 日本 | 99久久精品国产一区二区成人 | 国产高清好大好夹受不了了 | 亚洲五月综合缴情婷婷 | 高h猛烈做哭bl壮汉受欧美 | 国产二区自拍 | 欧美成人午夜精品一区二区 | 自拍偷拍国语对白 |