首頁  >  文章  >  web前端  >  javascript for-in有順序遍歷json資料並探討各個瀏覽器差異_javascript技巧

javascript for-in有順序遍歷json資料並探討各個瀏覽器差異_javascript技巧

WBOY
WBOY原創
2016-05-16 15:28:421604瀏覽

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

了解W3C標準:

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

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

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

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

新版本中的屬性遍歷順序說明與早期版本不同,這將導致遵循ECMA-262 第三版規範內容實現的JavaScript 解析引擎在處理for-in 語句時,與遵循第五版規範實現的解析引擎,對屬性的遍歷順序有不一致的問題。

 因此在開發中應盡量避免編寫依賴物件屬性順序的程式碼。如下:

<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程式碼在個瀏覽器差異:

以下透過一段程式碼單獨跟大家介紹JS 循環遍歷JSON資料

JSON資料如:

{"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> 
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn