国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

關(guān)于js中for...in循環(huán)對象時,輸出key值順序混亂問題

這篇具有很好參考價值的文章主要介紹了關(guān)于js中for...in循環(huán)對象時,輸出key值順序混亂問題。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

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

問題描述

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

js 循環(huán)對象key,javascript,前端,開發(fā)語言

當對象變?yōu)閺?fù)雜對象時,輸出的key就變得復(fù)雜

js 循環(huán)對象key,javascript,前端,開發(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方法對獲取的屬性名進行排序,newkey是一個數(shù)組
	var newObj = {};//創(chuàng)建一個新的對象,用于存放排好序的鍵值對
	for (var i = 0; i < newkey.length; i++) {//遍歷newkey數(shù)組
	    newObj[newkey[i]] = obj[newkey[i]];//向新創(chuàng)建的對象中按照排好的順序依次增加鍵值對
	}
	return newObj;//返回排好序的新對象
}

js 循環(huán)對象key,javascript,前端,開發(fā)語言

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

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

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

  • Object.keys(創(chuàng)建一個包含對象所有屬性的數(shù)組),
const fruits ={
    appple:22,
    pear:34,
    orange:88
}
var keys = Object.keys(fruits);
console.log(keys);  //["appple", "pear", "orange"]
  • Object.values(創(chuàng)建一個數(shù)組,其中包含對象中每個屬性的值),
const fruits ={
    appple:22,
    pear:34,
    orange:88
}

var values =Object.values(fruits);
console.log(values); //[22, 34, 88]
  • Object.entries(創(chuàng)建了一個二維數(shù)組,每個內(nèi)部數(shù)組都有2個元素,第一個元素是屬性名,第二個屬性值)
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對應(yīng)的方法也存在相同的問題,可以使用類似的方法進行修改

下面主要說的是 for…in

循環(huán)對象時,順序為什么會亂?

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

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

  • 整數(shù)屬性
String(Math.trunc(Number(prop)) === prop

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

例:

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

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

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

在v8 里是怎么樣存儲和讀取對象屬性的呢,

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

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

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

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

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

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

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

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

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

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

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

https://blog.csdn.net/wk15038187622/article/details/104062244文章來源地址http://www.zghlxwxcb.cn/news/detail-627948.html

到了這里,關(guān)于關(guān)于js中for...in循環(huán)對象時,輸出key值順序混亂問題的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • vue for循環(huán)不建議使用index作為key的原因

    先看下面一個例子: 當點擊按鈕時,會刪除數(shù)組第二個數(shù)據(jù),這樣就會導(dǎo)致原數(shù)組第二個數(shù)據(jù)之后數(shù)據(jù)的index發(fā)生改變,從而導(dǎo)致person3,和person4節(jié)點的更新,增加了額外的性能開銷; 如果將key由綁定index改為綁定id,上述性能開銷的問題就不會存在,因為更換key綁定時,刪除

    2024年02月02日
    瀏覽(23)
  • js遍歷對象key,value

    js遍歷對象key,value

    方法一:轉(zhuǎn)化為操作數(shù)組forEach遍歷 遍歷對象屬性 關(guān)于Object.keys()方法 Object.keys() 方法會返回一個由一個給定對象的自身可枚舉屬性組成的數(shù)組,數(shù)組中屬性名的排列順序和正常循環(huán)遍歷該對象時返回的順序一致。 例子 遍歷對象屬性值 關(guān)于Object.values()方法 object .values()靜態(tài)方

    2024年02月11日
    瀏覽(19)
  • RuntimeError: Error(s) in loading state_dict for ..:Missing key(s) in state_dict: …Unexpected key...

    原因:預(yù)訓(xùn)練權(quán)重層數(shù)的鍵值與新構(gòu)建的模型中的權(quán)重層數(shù)名稱不吻合,Checkpoint里面的模型是在雙卡上訓(xùn)練的,保存的key 前面都多一個module. 解決:model = torch.nn.DataParallel(model, device_ids=[0, 1]).cuda() torch.nn.DataParallel 是一種能夠?qū)?shù)據(jù)分散到多張顯卡上從而加快模型訓(xùn)練的方法

    2024年01月21日
    瀏覽(16)
  • 無涯教程-Javascript - For...in循環(huán)語句

    for ... in 循環(huán)用于循環(huán)訪問對象的屬性,由于無涯教程尚未討論 Objects 對象,您就會發(fā)現(xiàn)此循環(huán)非常有用。 “ for...in”循環(huán)的語法為: 在每次迭代中,將 object 對象中的一個屬性分配給 variablename 變量,此循環(huán)一直進行到對象的所有屬性。 請嘗試以下示例來實現(xiàn)\\\" for-in\\\"循環(huán),它

    2024年02月16日
    瀏覽(19)
  • js判斷對象是否擁有某個key

    方法一 : \\\"key\\\" in obj ,結(jié)果為 false,表示不包含;否則表示包含 方法二 : obj.hasOwnProperty(\\\"key\\\") ,obj 表示對象,結(jié)果為 false 表示不包含;否則表示包含 這兩種方法都可以用于檢查對象是否包含指定的屬性,但它們有一些區(qū)別。 “key” in obj: 這種方法使用 in 運算符來檢查屬

    2024年02月08日
    瀏覽(27)
  • (vue)獲取對象的鍵遍歷,同時循環(huán)el-tab頁展示key及內(nèi)容

    (vue)獲取對象的鍵遍歷,同時循環(huán)el-tab頁展示key及內(nèi)容

    效果: 數(shù)據(jù)結(jié)構(gòu): 代碼:

    2024年02月13日
    瀏覽(24)
  • matlab中的foreach、for in 循環(huán)、迭代器

    I 是個行向量,對于行向量,可以像上面的語法那樣在 for 循環(huán)中使用,遍歷 I 中的每一個元素。 如果 I 是列向量,就不行了。 可以看到 a 直接被賦值成整個列向量。 可見,for 循環(huán)中被用來迭代的矩陣會被看成只有一行,里面的元素是一個個列向量,for 循環(huán)一次取出里面的

    2024年02月11日
    瀏覽(30)
  • for循環(huán)的輸出控制(輸出1-100中的奇數(shù)、偶數(shù)、倍數(shù)以及公倍數(shù))

    一、輸出1-100中所有的奇數(shù): i = 1 while i = 100: ? ? if i%2 == 1: ? ? ? ? print(i) ? ? i += 1 ? 法二: for i in range(1,101): ? ? if i%2 == 1: ? ? ? ? print(i) ? 法三: for i in range(1,101,2): ? ??print(i) ? ? 二、輸出1-100中所有的偶數(shù): for i?in range(1,101): ? ? if i?% 2 == 0: ? ? ? ? print(i) ? 三、

    2024年02月08日
    瀏覽(20)
  • 數(shù)組的5種遍歷(for循環(huán)、for...in、for...of、forEach()、map()

    數(shù)組:內(nèi)存中一塊連續(xù)的存儲單元,這些存儲單元具有共同的名稱,不同的索引(下標)。 數(shù)組5種遍歷: 1、for循環(huán) ? ? ? ?任何數(shù)組都可以使用for循環(huán)進行遍歷,使用頻率最高 ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? for (let i = 0; i arr.length; i++) { ? ? ? ? ? ? ? ? ? ? ? ? ? ?

    2024年02月06日
    瀏覽(22)
  • js如何遍歷對象的key和value

    在JavaScript中,可以使用for…in循環(huán)來遍歷對象的鍵(key)和值(value)。以下是一個示例: 在這個例子中,for…in循環(huán)會遍歷對象obj的所有鍵。然后,hasOwnProperty函數(shù)會檢查這個鍵是否是對象obj自身的一個屬性,而不是從其原型鏈繼承的。如果是對象自己的屬性,就輸出這個鍵

    2024年02月10日
    瀏覽(24)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包