這篇文章主要介紹了js對象迭代方法與性能的比較,具有一定借鑒價值,需要的朋友可以參考下。如下資料是關于javascript對象迭代方法的詳細內容。
成都創新互聯專業為企業提供林州網站建設、林州做網站、林州網站設計、林州網站制作等企業網站建設、網頁設計與制作、林州企業網站模板建站服務,十載林州做網站經驗,不只是建網站,更提供有價值的思路和整體網絡服務。
Object.entries
返回對象所有可枚舉
的鍵值對,不會追尋原型鏈上的 key
let obj = { key1: 'value1', key2: 'value2', key3: 'value3', } Object.entries(obj).forEach(entry => { let key = entry[0] let value = entry[1] // entry 會是這樣 ["key1", "value1"] })
Object.keys
返回對象所有可枚舉的鍵
let obj = { key1: 'value1', key2: 'value2', key3: 'value3', } Object.keys(obj).forEach(key => { let value = obj[key] })
Object.values
返回對象所有可枚舉的值
let obj = { key1: 'value1', key2: 'value2', key3: 'value3', } Object.values(obj).forEach(value => { // 只能使用 value })
for…in loop
迭代可枚舉屬性,會順著原型鏈找下去
let obj = { key1: 'value1', key2: 'value2', key3: 'value3', } for (const key in obj) { let value = obj[key] if (obj.hasOwnProperty(key)) { // 本身的 } else { // 來自原型鏈的 } }
Object.getOwnPropertyNames
返回對象所有(包括不可枚舉)的鍵(原文說會找原型鏈是錯的)
let obj = { key1: 'value1', key2: 'value2', key3: 'value3', } Object.getOwnPropertyNames(obj).forEach(key => { let value = obj[key] })
性能比較
下面的代碼用上面的幾種方法遍歷有 1000000 個屬性的對象,循環 10 次
const { PerformanceObserver, performance } = require('perf_hooks') let objectSize = 1000000 let iterations = 10 console.log( 'Starting performance test with %d object size and %d iterations', objectSize, iterations ) let values = { ENTRIES: 0, KEYS: 0, VALUES: 0, FORIN: 0, GETOWP: 0, } const obs = new PerformanceObserver(items => { let entry = items.getEntries()[0] console.log(entry.name, entry.duration) values[entry.name] += entry.duration performance.clearMarks() }) obs.observe({ entryTypes: ['measure'] }) function generateObject() { let obj = {} for (let i = 0; i < objectSize; i++) { obj['key' + Math.random()] = 'val' + Math.random() } return obj } for (let i = 0; i < iterations; i++) { let obj = generateObject() //Object.entries performance.mark('A') Object.entries(obj).forEach(entry => { let key = entry[0] let value = entry[1] }) performance.mark('B') performance.measure('ENTRIES', 'A', 'B') //Object.Keys performance.mark('A') Object.keys(obj).forEach(key => { let value = obj[key] }) performance.mark('B') performance.measure('KEYS', 'A', 'B') //Object.Values performance.mark('A') Object.values(obj).forEach(value => {}) performance.mark('B') performance.measure('VALUES', 'A', 'B') //For In performance.mark('A') for (const key in obj) { let value = obj[key] } performance.mark('B') performance.measure('FORIN', 'A', 'B') //Object.getOwnPropertyNames performance.mark('A') Object.getOwnPropertyNames(obj).forEach(key => { let value = obj[key] }) performance.mark('B') performance.measure('GETOWP', 'A', 'B') } console.log( Object.entries(values).sort((a, b) => { return a[1] - b[1] }) )
下面的結果是我自己跑的,順序的是指賦值的時候直接用 index,隨機則是鍵值對都插入隨機數,得到的性能排序是和作者一樣的,也因為 node.js 和 chrome 都是 V8,所以這個應該也是代表在瀏覽器上的性能排序。
// 順序 ;[ ['FORIN', 4677.321499], ['KEYS', 4812.776572], ['GETOWP', 8610.906197], ['VALUES', 9914.674390999999], ['ENTRIES', 19338.083694], ] // 隨機 ;[ ['KEYS', 4502.579589], ['FORIN', 4678.013548000001], ['GETOWP', 8880.325031999999], ['VALUES', 10104.106962], ['ENTRIES', 17089.637588999998], ]
之前聽說引擎會猜測下一個值讓運行速度更快,看數據似乎沒有太大影響。
以上就是js對象迭代方法與性能比較的詳細內容了,看完之后是否有所收獲呢?如果想了解更多相關內容,歡迎關注創新互聯行業資訊!
文章名稱:js對象迭代方法與性能的比較
文章地址:http://vcdvsql.cn/article18/ggphdp.html
成都網站建設公司_創新互聯,為您提供云服務器、外貿建站、自適應網站、ChatGPT、網站導航、
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯