一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

XML的代替者----JSON

我個人覺得phpJavascript各有長處,如果能完美的結(jié)合起來,那將創(chuàng)造出許許多多的奇跡! 我是初次寫此類文章,Bug難免,請各位指正~ 
    現(xiàn)在AJAX應(yīng)用非常流行,而在AJAX中客戶端Javascript和服務(wù)端動態(tài)腳本的通信是關(guān)鍵。如果傳輸?shù)男畔⒈容^簡單,通常我們會直接采用字符串的方式,如果信息結(jié)構(gòu)復(fù)雜一點,則通常用XML文檔。XML文檔雖然應(yīng)用廣泛,但是用php生成和用Javascript處理卻不是一件很容易的事情。這里我推薦一種XML文檔的比較好簡化替代方案:JSON! 
    首先我們來了解一下Javascript的基礎(chǔ)知識。 
    1.創(chuàng)建數(shù)組,可以用JS內(nèi)建的類Array來初始化,也可以用JSON符號"[]"。下面通過兩種方式創(chuàng)建的arr1和arr2的實質(zhì)是一樣的: 

var arr1 = new Array(); 
arr1[0] = "apple"; 
arr1[1] = "google"; 
arr1[2] = "longbill"; 

var arr2 = ["apple","google","longbill"];
注意,數(shù)組的索引也可以是字符串,如 arr1["name"] = "longbill"; 這時的數(shù)組就相當于對象了。。。 
    2.創(chuàng)建對象,可以用JS內(nèi)建的類Object來初始化,也可以用JSON符號"{}"。下面通過兩種方式創(chuàng)建的obj1和ob2的實質(zhì)也是一樣的: 


var obj1 = new Object(); 
obj1.name = "longbill"; 
obj1.age = 18; 

var obj2 = { name:"longbill",age:18 };
注意,這里"{"和"}"之間必須寫成"鍵:值"的形式,而且不同的"鍵:值"之間要用","分割。 "鍵"中也可以包含空格等特殊字符,此時要用""(引號)來引用,如 "phone number":123456 
    其實在JS中,數(shù)組的本質(zhì)是一個對象,對象本身也是一個數(shù)組。所以, obj1.name 和 obj1["name"] 是同一個引用。 
    我們還可以通過JSON符號的嵌套來定義復(fù)雜的S對象: 


var people = [ 
    { 
        name:"longbill", 
        age:18 
    }, 
    { 
        name:"neal", 
        age:19 
    }, 
    { 
        name:"glocklee", 
        age:17 
    } 
];
//這個應(yīng)該看的懂吧~~ 
大部分XML文檔都可以用JSON來表達: 


<?xml version="1.0"?> 
<root> 
  <book> 
    <name>Ju love</name> 
    <price>$15</price> 
  </book> 
  <book> 
    <name>Javascrip</name> 
    <price>$25</price> 
  </book> 
</root>

如果用JSON就可以表達為: 


root: 

  { 
     name:"Ju love", 
     price:"$15" 
  }, 
  { 
     name:"Javascript", 
     price:"$25" 
  } 
]}

是不是簡化很多? 

    而且客戶端JS處理起來也很簡單,只要用執(zhí)行字符串函數(shù) "eval" 就可以將JSON信息提取出來,而如果是XML文檔,那就不的不用大量的標準DOM操作來提取其中的數(shù)據(jù)。如: 


//已經(jīng)用AJAX從服務(wù)端下載了一個JSON文件(字符串),保存在變量 json 里 
eval("var myvar = "+json); 
//這樣,JSON里的信息就表達在myvar這個變量里了。
缺點:一旦JSON的格式錯誤,將導(dǎo)致服務(wù)端JS系統(tǒng)錯誤,甚至崩潰。 
   解決辦法: 
   最好在eval之前使用try(試探執(zhí)行),如 


//已經(jīng)用AJAX從服務(wù)端下載了一個JSON文件(字符串),保存在變量 json 里 
try { 
    eval("var myvar = "+json); 
} catch(e) { alert('json syntax error!'); } 
//這樣,即使JSON格式錯誤,也只會彈出一個提示框,而不會拋出一個腳本錯誤!

JavaScript技術(shù)XML的代替者----JSON,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产精品久久久久久久久久一区 | 四虎8848精品永久在线观看 | 国产精品视频第一区二区三区 | 91精品国产免费入口 | 亚洲经典在线中文字幕 | 国产在线麻豆自在拍91精品 | bt7086福利一区二区三区最新 | 国产精品无| 亚洲成综合人影院在院播放 | 色多多污在线观看 | 精品视频在线观看一区二区三区 | 精品欧美亚洲韩国日本久久 | 在线高清免费爱做网 | 五月激情天 | 色四虎| 激情网成人 | 亚洲一区二区视频在线观看 | 伊人网综合视频 | 99国产国人青青视频在线观看 | 性欧美xxxx视频在线观看 | 免费在线视频一区 | 亚洲国产婷婷香蕉久久久久久 | 男女爱爱爽爽福利免费视频 | 麻豆精品国产自产在线 | 久久久青草青青国产亚洲免观 | 国产激情视频趣趣在线观看的 | 精品一区二区三区的国产在线观看 | 91免费影视 | 久久免费99精品国产自在现线 | 免费伦费一区二区三区四区 | 小视频在线观看免费 | 国产成人久久蜜一区二区 | 国产91免费在线观看 | 在线日本妇人成熟免费观看 | 一区二区三区四区免费视频 | 久久se精品动漫一区二区三区 | 久热久操 | 成人精品视频在线观看播放 | dxj在线视频·男人的天堂网站 | 亚洲第一黄色网址 | 亚洲欧美婷婷 |