欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js中for...in循環(huán)對(duì)象時(shí)輸出key值順序混亂問題解決

 更新時(shí)間:2023年11月09日 10:22:46   作者:硯言  
很久之前就有前輩告訴我用for...in循環(huán)對(duì)象屬性的順序不是固定的,xiam?這篇文章主要給大家介紹了關(guān)于js中for...in循環(huán)對(duì)象時(shí)輸出key值順序混亂問題解決方法,需要的朋友可以參考下

解決循環(huán)復(fù)雜對(duì)象,key值順序混亂

問題描述

當(dāng)循環(huán)純數(shù)字索引對(duì)象時(shí),循環(huán)key值是正確的

當(dāng)對(duì)象變?yōu)閺?fù)雜對(duì)象時(shí),輸出的key就變得復(fù)雜

解決方案

//循環(huán)中使用
for(let item in this.objectOrder(data)){
	this.objArr.push(item)
}
 
//方法
objectOrder(obj) {//排序的函數(shù)
	var newkey = Object.keys(obj).sort(); //先用Object內(nèi)置類的keys方法獲取要排序?qū)ο蟮膶傩悦?,再利用Array原型上的sort方法對(duì)獲取的屬性名進(jìn)行排序,newkey是一個(gè)數(shù)組
	var newObj = {};//創(chuàng)建一個(gè)新的對(duì)象,用于存放排好序的鍵值對(duì)
	for (var i = 0; i < newkey.length; i++) {//遍歷newkey數(shù)組
	    newObj[newkey[i]] = obj[newkey[i]];//向新創(chuàng)建的對(duì)象中按照排好的順序依次增加鍵值對(duì)
	}
	return newObj;//返回排好序的新對(duì)象
}

循環(huán)對(duì)象時(shí),輸出key值順序混亂原因

ES6之前,循環(huán)對(duì)象常見做法是使用:for…in。但是for…in循環(huán)的問題在于它會(huì)遍歷原型鏈中的屬性,所以需要使用hasOwnProperty執(zhí)行檢查屬性是否屬于該對(duì)象。

ES6之后,我們對(duì)于對(duì)象的循環(huán)有了更好的辦法:

Object.keys(創(chuàng)建一個(gè)包含對(duì)象所有屬性的數(shù)組),

const fruits ={
    appple:22,
    pear:34,
    orange:88
}
var keys = Object.keys(fruits);
console.log(keys);  //["appple", "pear", "orange"]

Object.values(創(chuàng)建一個(gè)數(shù)組,其中包含對(duì)象中每個(gè)屬性的值),

const fruits ={
    appple:22,
    pear:34,
    orange:88
}

var values =Object.values(fruits);
console.log(values); //[22, 34, 88]

Object.entries(創(chuàng)建了一個(gè)二維數(shù)組,每個(gè)內(nèi)部數(shù)組都有2個(gè)元素,第一個(gè)元素是屬性名,第二個(gè)屬性值)

const fruits ={
    appple:22,
    pear:34,
    orange:88
}
var entries = Object.entries(fruits);
console.log(entries);
// [['appple',22],['pear',34],['orange',88]]
const fruits ={
    appple:22,
    pear:34,
    orange:88
}
for (const [fruit,num] of entries) {
    console.log(`we have ${num} ${fruit}`);  //we have 22 appple ...
}

Object對(duì)應(yīng)的方法也存在相同的問題,可以使用類似的方法進(jìn)行修改

下面主要說的是 for…in

循環(huán)對(duì)象時(shí),順序?yàn)槭裁磿?huì)亂?

1.這本身就是一個(gè)ECMA的一個(gè)規(guī)范,數(shù)字按升序輸出,字符串按創(chuàng)建順序輸出,并且數(shù)字優(yōu)先級(jí)高于字符串
2.JS本身是不能被計(jì)算機(jī)識(shí)別,需要通過V8轉(zhuǎn)化為字節(jié)碼
3.那么針對(duì)ECMA的一個(gè)規(guī)范,v8對(duì)這個(gè)規(guī)范做的優(yōu)化策略
4.排序?qū)傩?elements,用來存儲(chǔ)數(shù)字。 常規(guī)屬性 properties 用來存儲(chǔ)字符串。為了優(yōu)化,引入對(duì)象內(nèi)屬性
5.對(duì)象屬性多后,會(huì)采用慢屬性來存儲(chǔ)數(shù)據(jù),快屬性就是采用線性數(shù)據(jù)結(jié)構(gòu),慢屬性就是采用非線性結(jié)構(gòu),比如字典來存儲(chǔ)數(shù)據(jù)。

1. 先遍歷出整數(shù)屬性(integer properties,按照升序),然后其他屬性按照創(chuàng)建時(shí)候的順序遍歷出來。

整數(shù)屬性

String(Math.trunc(Number(prop)) === prop

當(dāng)上面的判斷結(jié)果為 true,prop 就是整數(shù)屬性,否則不是。

例:

"49" 是整數(shù)屬性,因?yàn)?String(Math.trunc(Number('49')) 的結(jié)果還是 "49"。
"+49" 不是整數(shù)屬性,因?yàn)?String(Math.trunc(Number('+49')) 的結(jié)果是 "49",不是 "+49"。
"1.2" 不是整數(shù)屬性,因?yàn)?String(Math.trunc(Number('1.2')) 的結(jié)果是 "1",不是 "1.2"。

「數(shù)字屬性應(yīng)該按照索引值??升序排列,字符串屬性根據(jù)創(chuàng)建時(shí)的順序升序排列。并且數(shù)字屬性優(yōu)先于字符串」

2. 首先JS代碼本身是不會(huì)直接被計(jì)算機(jī)執(zhí)行,計(jì)算機(jī)只能接收二進(jìn)制的匯編代碼,所以,中間需要一層轉(zhuǎn)化,而這個(gè)轉(zhuǎn)化,在chrom就是v8引擎

在v8 里是怎么樣存儲(chǔ)和讀取對(duì)象屬性的呢,

1. 在v8里,將對(duì)象里的屬性,分為兩大類。數(shù)字類型,叫排序?qū)傩?在v8里叫elements。字符串類型,叫常規(guī)屬性,在v8里叫properties。
在v8里,為了有效的存儲(chǔ)和訪問這對(duì)象屬性,分別使用兩個(gè)線性結(jié)構(gòu)來保存這兩個(gè)屬性。

2. 在elements對(duì)象中,會(huì)按照順序存放排序?qū)傩裕琾roperties屬性則指向了properties對(duì) 象,在properties對(duì)象中,會(huì)按照創(chuàng)建時(shí)的順序保存了常規(guī)屬性。

3. 但是這樣也存在一個(gè)問題,在查找排序?qū)傩詴r(shí),直接通過索引即可。但是對(duì)象,需要找到properties,然后找到propteries里的屬性,這樣無(wú)疑多了一層操作,所以引入了一個(gè)新名詞 對(duì)象內(nèi)屬性( in- object properties)

4. 但是常規(guī)屬性也有個(gè)數(shù)限制,超過是個(gè),默認(rèn)是10個(gè),就要開辟新的空間來保存常規(guī)屬性

針對(duì)數(shù)量少的對(duì)象屬性,采用以上策略完全沒有問題,但是對(duì)象數(shù)量多了以后,會(huì)采用排序非線性字典結(jié)構(gòu)來存儲(chǔ)

  • 線性結(jié)構(gòu):是一個(gè)有序數(shù)據(jù)元素的集合。常見線性結(jié)構(gòu), 線性表,棧,隊(duì)列,雙隊(duì)列,串(一維數(shù)組)
  • 非線性結(jié)構(gòu): 其邏輯特征是一個(gè)結(jié)點(diǎn)元素可能有多個(gè)直接前驅(qū)和多個(gè)直接后繼。

那這個(gè)時(shí)候,通過線性結(jié)構(gòu)來存儲(chǔ)數(shù)據(jù),查找肯定的快的,但是如果涉及到大量的修改數(shù)據(jù),那么動(dòng)一發(fā)而牽全身,是非常耗性能的,所以數(shù)據(jù)多了,v8采用了慢排序

  • 快排序: 采用線性結(jié)構(gòu)
  • 慢排序:采用非線性結(jié)構(gòu) ,比如字典

3. 同時(shí)與瀏覽器有關(guān)系,Chrome跟IE是不一樣的,所以給出以下結(jié)論:

Chrome Opera 的 JavaScript 解析引擎遵循的是新版 ECMA-262 第五版規(guī)范。因此,使用 for-in 語(yǔ)句遍歷對(duì)象屬性時(shí)遍歷書序并非屬性構(gòu)建順序。
而 IE6 IE7 IE8 Firefox Safari 的 JavaScript 解析引擎遵循的是較老的 ECMA-262 第三版規(guī)范,屬性遍歷順序由屬性構(gòu)建的順序決定。

Chrome Opera 中使用 for-in 語(yǔ)句遍歷對(duì)象屬性時(shí)會(huì)遵循一個(gè)規(guī)律:
它們會(huì)先提取所有 key 的 parseFloat 值為非負(fù)整數(shù)的屬性,然后根據(jù)數(shù)字順序?qū)傩耘判蚴紫缺闅v出來,然后按照對(duì)象定義的順序遍歷余下的所有屬性。

http://www.dbjr.com.cn/javascript/304306x8c.htm

總結(jié)

到此這篇關(guān)于js中for...in循環(huán)對(duì)象時(shí)輸出key值順序混亂問題解決的文章就介紹到這了,更多相關(guān)js for...in循環(huán)輸出key值順序混亂內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 使用echarts實(shí)現(xiàn)3d柱狀圖+折線圖

    使用echarts實(shí)現(xiàn)3d柱狀圖+折線圖

    這篇文章主要為大家詳細(xì)介紹了如何使用echarts實(shí)現(xiàn)3d柱狀圖和折線圖,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,有需要的小伙伴可以了解一下
    2024-12-12
  • layui多圖上傳實(shí)現(xiàn)刪除功能的例子

    layui多圖上傳實(shí)現(xiàn)刪除功能的例子

    今天小編就為大家分享一篇layui多圖上傳實(shí)現(xiàn)刪除功能的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • Bootstrap4如何定制自己的顏色和風(fēng)格

    Bootstrap4如何定制自己的顏色和風(fēng)格

    這篇文章主要介紹了Bootstrap4如何定制自己的顏色和風(fēng)格,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-02-02
  • Bootstrap選項(xiàng)卡學(xué)習(xí)筆記分享

    Bootstrap選項(xiàng)卡學(xué)習(xí)筆記分享

    這篇文章主要為大家詳細(xì)介紹了Bootstrap選項(xiàng)卡學(xué)習(xí)筆記,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • 微信公眾號(hào)平臺(tái)接口開發(fā) 獲取access_token過程解析

    微信公眾號(hào)平臺(tái)接口開發(fā) 獲取access_token過程解析

    這篇文章主要介紹了微信公眾號(hào)平臺(tái)接口開發(fā) 獲取access_token過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-08-08
  • JS中實(shí)現(xiàn)函數(shù)return多個(gè)返回值的實(shí)例

    JS中實(shí)現(xiàn)函數(shù)return多個(gè)返回值的實(shí)例

    下面小編就為大家?guī)硪黄狫S中實(shí)現(xiàn)函數(shù)return多個(gè)返回值的實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-02-02
  • Webpack打包過程中處理ES6模塊的循環(huán)依賴問題小結(jié)

    Webpack打包過程中處理ES6模塊的循環(huán)依賴問題小結(jié)

    Webpack通過“暫時(shí)性引用”特性處理ES6模塊的循環(huán)依賴,即在模塊加載時(shí)創(chuàng)建占位符,確保模塊能夠正確加載,本文介紹Webpack打包過程中如何處理ES6模塊的循環(huán)依賴,感興趣的朋友一起看看吧
    2025-02-02
  • 你不知道的高性能JAVASCRIPT

    你不知道的高性能JAVASCRIPT

    想必大家都知道,JavaScrip是全棧開發(fā)語(yǔ)言,瀏覽器,手機(jī),服務(wù)器端都可以看到JS的身影。 本文會(huì)分享一些高效的JavaScript的最佳實(shí)踐,提高大家對(duì)JS的底層和實(shí)現(xiàn)原理的理解,感興趣的小伙伴們可以參考一下
    2016-01-01
  • 如何在js中計(jì)算兩個(gè)時(shí)間段重疊的時(shí)長(zhǎng)問題詳解

    如何在js中計(jì)算兩個(gè)時(shí)間段重疊的時(shí)長(zhǎng)問題詳解

    這篇文章主要給大家介紹了關(guān)于如何在js中計(jì)算兩個(gè)時(shí)間段重疊的時(shí)長(zhǎng)問題的相關(guān)資料,判斷兩個(gè)時(shí)間段是否重疊可以通過比較兩個(gè)時(shí)間段的開始時(shí)間和結(jié)束時(shí)間來實(shí)現(xiàn),文中通過代碼示例介紹的非常詳細(xì),需要的朋友可以參考下
    2024-04-04
  • javascript進(jìn)行四舍五入方法匯總

    javascript進(jìn)行四舍五入方法匯總

    這篇文章主要介紹了javascript進(jìn)行四舍五入方法匯總,并給出了相關(guān)示例,需要的朋友可以參考下
    2014-12-12

最新評(píng)論