javascript - js中數(shù)組的undefined為什么不會被遍歷
問題描述
問題描述并不全面
我的問題是,當(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)該都是可以正常打印的
相關(guān)文章:
1. javascript - 在 vue里面用import引入js文件,結(jié)果為undefined2. html - 爬蟲時出現(xiàn)“DNS lookup failed”,打開網(wǎng)頁卻沒問題,這是什么情況?3. 求教一個mysql建表分組索引問題4. 小程序怎么加外鏈,語句怎么寫!求救新手,開文檔沒發(fā)現(xiàn)5. html5 - input type=’file’ 上傳獲取的fileList對象怎么存儲于瀏覽器?6. 求救一下,用新版的phpstudy,數(shù)據(jù)庫過段時間會消失是什么情況?7. python沒入門,請教一個問題8. php如何獲取訪問者路由器的mac地址9. node.js - 用nodejs 的node-xlsx模塊去讀取excel中的數(shù)據(jù),可是讀取出來的日期是數(shù)字,請問該如何讀取日期呢?10. javascript - 我的站點貌似被別人克隆了, google 搜索特定文章,除了域名不一樣,其他的都一樣,如何解決?
