日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
創(chuàng)新互聯(lián)JSON教程:JSON數(shù)據(jù)遍歷之for-in

object 本身就是無對象的集合,因此在用 for-in 語句遍歷對象的屬性時,遍歷出的屬性順序與對象定義時不同。

成都創(chuàng)新互聯(lián)服務(wù)項目包括桂平網(wǎng)站建設(shè)、桂平網(wǎng)站制作、桂平網(wǎng)頁制作以及桂平網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,桂平網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到桂平省份的部分城市,未來相信會繼續(xù)擴大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!

W3C標準

根據(jù) ECMA-262(ECMAScript)第三版中描述,for-in 語句的屬性遍歷的順序是由對象定義時屬性的書寫順序決定的。

關(guān)于 ECMA-262(ECMAScript)第三版中 for-in 語句的更多信息,請參考 ECMA-262 3rd Edition 中 12.6.4 The for-in Statement。

在現(xiàn)有最新的 ECMA-262(ECMAScript)第五版規(guī)范中,對 for-in 語句的遍歷機制又做了調(diào)整,屬性遍歷的順序是沒有被規(guī)定的。

關(guān)于 ECMA-262(ECMAScript)第五版中 for-in 語句的更多信息,請參考 ECMA-262 5rd Edition 中 12.6.4 The for-in Statement。

新版本中的屬性遍歷順序說明與早期版本不同,這將導(dǎo)致遵循 ECMA-262 第三版規(guī)范內(nèi)容實現(xiàn)的 JavaScript 解析引擎在處理 for-in 語句時,與遵循第五版規(guī)范實現(xiàn)的解析引擎,對屬性的遍歷順序存在不一致的問題。

 因此在開發(fā)中應(yīng)盡量避免編寫依賴對象屬性順序的代碼。如下:

var JSON1 = {
    "2":{"name":"第1條"},
    "1":{"name":"第2條"},
    "3":{"name":"第3條"}
}
var json2 = [
    {"name":"第1條"},
    {"name":"第2條"},
    {"name":"第3條"}
]
for(var i in json1){
    alert(json1[i].name);
}
//正確
for(var i in json2){
    alert(json2[i].name);
}

看看for-in代碼在個瀏覽器差異:

下面通過一段代碼單獨給大家介紹JS 循環(huán)遍歷JSON數(shù)據(jù)
JSON數(shù)據(jù)如:

{"options":"[{/"text/":/"王家灣/",/"value/":/"9/"},{/"text/":/"李家灣/",/"valu
e/":/"10/"},{/"text/":/"邵家灣/",/"value/":/"13/"}]"}

用js可以寫成:

var data=[{name:"a",age:12},{name:"b",age:11},{name:"c",age:13},{name:"d",age:14}]; 
   for(var o in data){ 
    alert(o); 
    alert(data[o]); 
    alert("text:"+data[o].name+" value:"+data[o].age ); 
   }

或者是:

javascript數(shù)組遍歷for與for in區(qū)別詳解

js中遍歷數(shù)組的有兩種方式

代碼如下:

var array = ['a']
//標準的for循環(huán)
for (var i = 1; i < array.length; i++) {
    alert(array[i])
}
//foreach循環(huán)
for (var i in array) {
    alert(array[i])
}

正常情況下上面兩種遍歷數(shù)組的方式結(jié)果一樣。首先說兩者的第一個區(qū)別

標準的for循環(huán)中的i是number類型,表示的是數(shù)組的下標,但是foreach循環(huán)中的i表示的是數(shù)組的key是string類型,因為js中一切皆為對象。自己試試 alert(typeof i);這個區(qū)別是小問題。現(xiàn)在我加上如下代碼,上面的執(zhí)行結(jié)果就不一樣了。

代碼如下:

//擴展了js原生的Array
Array.prototype.test=function(){
 
}

試試看上面的代碼執(zhí)行什么。我們發(fā)現(xiàn)標準的for循環(huán)任然真正的對數(shù)組循環(huán), 但是此時foreach循環(huán)對我剛才寫的test方法寫打印出來了。這就是for與foreach遍歷數(shù)組的最大區(qū)別,如果我們在項目采用的是用foreach遍歷數(shù)組,假設(shè)有一天誰不小心自己為了擴展js原生的Array類,或者引入一個外部的js框架也擴展了原生Array。那問題就來了。

再此建議兩點

1.不要用for in遍歷數(shù)組,全部統(tǒng)一采用標準的for循環(huán)變量數(shù)組(我們無法保證我們引入的js是否會采用prototype擴展原生的Array)
2.如果要對js的原生類擴展的時候,不要采用prototype了


網(wǎng)頁題目:創(chuàng)新互聯(lián)JSON教程:JSON數(shù)據(jù)遍歷之for-in
文章路徑:http://m.5511xx.com/article/dhdeeih.html