W3Cschool
恭喜您成為首批注冊(cè)用戶
獲得88經(jīng)驗(yàn)值獎(jiǎng)勵(lì)
object 本身就是無(wú)對(duì)象的集合,因此在用 for-in 語(yǔ)句遍歷對(duì)象的屬性時(shí),遍歷出的屬性順序與對(duì)象定義時(shí)不同。
根據(jù) ECMA-262(ECMAScript)第三版中描述,for-in 語(yǔ)句的屬性遍歷的順序是由對(duì)象定義時(shí)屬性的書(shū)寫(xiě)順序決定的。
關(guān)于 ECMA-262(ECMAScript)第三版中 for-in 語(yǔ)句的更多信息,請(qǐng)參考 ECMA-262 3rd Edition 中 12.6.4 The for-in Statement。
在現(xiàn)有最新的 ECMA-262(ECMAScript)第五版規(guī)范中,對(duì) for-in 語(yǔ)句的遍歷機(jī)制又做了調(diào)整,屬性遍歷的順序是沒(méi)有被規(guī)定的。
關(guān)于 ECMA-262(ECMAScript)第五版中 for-in 語(yǔ)句的更多信息,請(qǐng)參考 ECMA-262 5rd Edition 中 12.6.4 The for-in Statement。
新版本中的屬性遍歷順序說(shuō)明與早期版本不同,這將導(dǎo)致遵循 ECMA-262 第三版規(guī)范內(nèi)容實(shí)現(xiàn)的 JavaScript 解析引擎在處理 for-in 語(yǔ)句時(shí),與遵循第五版規(guī)范實(shí)現(xiàn)的解析引擎,對(duì)屬性的遍歷順序存在不一致的問(wèn)題。
因此在開(kāi)發(fā)中應(yīng)盡量避免編寫(xiě)依賴(lài)對(duì)象屬性順序的代碼。如下:
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代碼在個(gè)瀏覽器差異:
下面通過(guò)一段代碼單獨(dú)給大家介紹JS 循環(huán)遍歷JSON數(shù)據(jù)
JSON數(shù)據(jù)如:
{"options":"[{/"text/":/"王家灣/",/"value/":/"9/"},{/"text/":/"李家灣/",/"valu
e/":/"10/"},{/"text/":/"邵家灣/",/"value/":/"13/"}]"}
用js可以寫(xiě)成:
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 );
}
或者是:
<script type="text/javascript">
function text(){
var json = {"options":"[{/"text/":/"王家灣/",/"value/":/"9/"},{/"text/":/"李家灣/",/"value/":/"10/"},{/"text/":/"邵家灣/",/"value/":/"13/"}]"}
json = eval(json.options)
for(var i=0; i<json.length; i++)
{
alert(json[i].text+" " + json[i].value)
}
}
</script>
js中遍歷數(shù)組的有兩種方式
var array = ['a']
//標(biāo)準(zhǔn)的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é)果一樣。首先說(shuō)兩者的第一個(gè)區(qū)別
標(biāo)準(zhǔn)的for循環(huán)中的i是number類(lèi)型,表示的是數(shù)組的下標(biāo),但是foreach循環(huán)中的i表示的是數(shù)組的key是string類(lèi)型,因?yàn)閖s中一切皆為對(duì)象。自己試試 alert(typeof i);這個(gè)區(qū)別是小問(wèn)題?,F(xiàn)在我加上如下代碼,上面的執(zhí)行結(jié)果就不一樣了。
//擴(kuò)展了js原生的Array
Array.prototype.test=function(){
}
再此建議兩點(diǎn)
1.不要用for in遍歷數(shù)組,全部統(tǒng)一采用標(biāo)準(zhǔn)的for循環(huán)變量數(shù)組(我們無(wú)法保證我們引入的js是否會(huì)采用prototype擴(kuò)展原生的Array)
2.如果要對(duì)js的原生類(lèi)擴(kuò)展的時(shí)候,不要采用prototype了
Copyright©2021 w3cschool編程獅|閩ICP備15016281號(hào)-3|閩公網(wǎng)安備35020302033924號(hào)
違法和不良信息舉報(bào)電話:173-0602-2364|舉報(bào)郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號(hào)
聯(lián)系方式:
更多建議: