javascript for-in有序遍歷json數(shù)據(jù)并探討各個(gè)瀏覽器差異
object本身就是無對象的集合,因此在用 for-in 語句遍歷對象的屬性時(shí),遍歷出的屬性順序與對象定義時(shí)不同。
了解W3C標(biāo)準(zhǔn):
根據(jù) ECMA-262(ECMAScript)第三版中描述,for-in 語句的屬性遍歷的順序是由對象定義時(shí)屬性的書寫順序決定的。
關(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 語句的遍歷機(jī)制又做了調(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)容實(shí)現(xiàn)的 JavaScript 解析引擎在處理 for-in 語句時(shí),與遵循第五版規(guī)范實(shí)現(xiàn)的解析引擎,對屬性的遍歷順序存在不一致的問題。
因此在開發(fā)中應(yīng)盡量避免編寫依賴對象屬性順序的代碼。如下:
<script>
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);
}
</script>
看看for-in代碼在個(gè)瀏覽器差異:

下面通過一段代碼單獨(dú)給大家介紹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 );
}
或是
<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>
- jQuery使用$.each遍歷json數(shù)組的簡單實(shí)現(xiàn)方法
- JQuery遍歷json數(shù)組的3種方法
- jQuery 遍歷json數(shù)組的實(shí)現(xiàn)代碼
- jQuery遍歷json中多個(gè)map的方法
- JS循環(huán)遍歷JSON數(shù)據(jù)的方法
- js 遍歷json返回的map內(nèi)容示例代碼
- 通過Jquery遍歷Json的兩種數(shù)據(jù)結(jié)構(gòu)的實(shí)現(xiàn)代碼
- Javascript Jquery 遍歷Json的實(shí)現(xiàn)代碼
- JS簡單循環(huán)遍歷json數(shù)組的方法
相關(guān)文章
JavaScript里四舍五入函數(shù)round用法實(shí)例
這篇文章主要介紹了JavaScript里四舍五入函數(shù)round用法,實(shí)例分析了round函數(shù)的使用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-04-04
js 下拉菜單點(diǎn)擊旁邊收起實(shí)現(xiàn)(踩坑記)
這篇文章主要介紹了js 下拉菜單點(diǎn)擊旁邊收起實(shí)現(xiàn)(踩坑記),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09
JS當(dāng)前頁面登錄注冊框,固定DIV,底層陰影的實(shí)例代碼
下面小編就為大家?guī)硪黄狫S當(dāng)前頁面登錄注冊框,固定DIV,底層陰影的實(shí)例代碼。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-09-09
JavaScript閉包原理與用法學(xué)習(xí)筆記
這篇文章主要介紹了JavaScript閉包原理與用法,結(jié)合實(shí)例形式詳細(xì)分析了JavaScript閉包相關(guān)概念、原理、用法及操作注意事項(xiàng),需要的朋友可以參考下2020-05-05
JavaScript數(shù)據(jù)綁定實(shí)現(xiàn)一個(gè)簡單的 MVVM 庫
MVVM 是 Web 前端一種非常流行的開發(fā)模式,利用 MVVM 可以使我們的代碼更專注于處理業(yè)務(wù)邏輯而不是去關(guān)心DOM 操作。接下來通過本文給大家介紹JavaScript使用數(shù)據(jù)綁定實(shí)現(xiàn)一個(gè)簡單的 MVVM 庫,感興趣的朋友一起學(xué)習(xí)吧2016-04-04

