亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

javascript for-in有序遍歷json數(shù)據(jù)并探討各個瀏覽器差異

 更新時間:2015年11月30日 11:41:28   投稿:mrr  
這篇文章主要介紹了javascript for-in有序遍歷json數(shù)據(jù)并探討各個瀏覽器差異的相關資料,需要的朋友可以參考下

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

了解W3C標準:

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

關于 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ī)定的。

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

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

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

<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 循環(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> 

相關文章

  • JavaScript里四舍五入函數(shù)round用法實例

    JavaScript里四舍五入函數(shù)round用法實例

    這篇文章主要介紹了JavaScript里四舍五入函數(shù)round用法,實例分析了round函數(shù)的使用技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-04-04
  • js 下拉菜單點擊旁邊收起實現(xiàn)(踩坑記)

    js 下拉菜單點擊旁邊收起實現(xiàn)(踩坑記)

    這篇文章主要介紹了js 下拉菜單點擊旁邊收起實現(xiàn)(踩坑記),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-09-09
  • JS當前屬性查詢實現(xiàn)代碼

    JS當前屬性查詢實現(xiàn)代碼

    JS中的for in 可遍歷變量的所有屬性!利用此特性制作了一個JS當前屬性查詢!
    2010-12-12
  • JS當前頁面登錄注冊框,固定DIV,底層陰影的實例代碼

    JS當前頁面登錄注冊框,固定DIV,底層陰影的實例代碼

    下面小編就為大家?guī)硪黄狫S當前頁面登錄注冊框,固定DIV,底層陰影的實例代碼。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-09-09
  • JavaScript閉包原理與用法學習筆記

    JavaScript閉包原理與用法學習筆記

    這篇文章主要介紹了JavaScript閉包原理與用法,結合實例形式詳細分析了JavaScript閉包相關概念、原理、用法及操作注意事項,需要的朋友可以參考下
    2020-05-05
  • js取得html iframe中的元素和變量值

    js取得html iframe中的元素和變量值

    想要取得iframe中的元素和js變量值,不能用$(document).ready()方法,而是要用$("#iframeId").load()方法
    2014-06-06
  • 微信小程序學習之自定義滾動彈窗

    微信小程序學習之自定義滾動彈窗

    這篇文章主要給大家介紹了關于微信小程序學習之自定義滾動彈窗的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-12-12
  • JavaScript數(shù)據(jù)綁定實現(xiàn)一個簡單的 MVVM 庫

    JavaScript數(shù)據(jù)綁定實現(xiàn)一個簡單的 MVVM 庫

    MVVM 是 Web 前端一種非常流行的開發(fā)模式,利用 MVVM 可以使我們的代碼更專注于處理業(yè)務邏輯而不是去關心DOM 操作。接下來通過本文給大家介紹JavaScript使用數(shù)據(jù)綁定實現(xiàn)一個簡單的 MVVM 庫,感興趣的朋友一起學習吧
    2016-04-04
  • JS隱藏參數(shù)post傳值實例

    JS隱藏參數(shù)post傳值實例

    JS隱藏參數(shù)post傳值實例,需要的朋友可以參考一下
    2013-04-04
  • JavaScript獲取路徑設計源碼

    JavaScript獲取路徑設計源碼

    JavaScript獲取路徑的方法有很多,網(wǎng)上也可以搜索的到,下面本例也要為大家講解下,有源碼及結果截圖
    2014-05-05

最新評論