天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

XML的代替者----JSON

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

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

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


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

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


var people = [ 
    { 
        name:"longbill", 
        age:18 
    }, 
    { 
        name:"neal", 
        age:19 
    }, 
    { 
        name:"glocklee", 
        age:17 
    } 
];
//這個應該看的懂吧~~ 
大部分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í)行字符串函數 "eval" 就可以將JSON信息提取出來,而如果是XML文檔,那就不的不用大量的標準DOM操作來提取其中的數據。如: 


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


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

JavaScript技術XML的代替者----JSON,轉載需保留來源!

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

主站蜘蛛池模板: 欧美精品乱码99久久蜜桃 | 秋霞电影网午夜鲁丝片无码 | 国产成人免费在线观看 | 日韩欧美精品有码在线播放免费 | 亚洲欧美精品无码一区二在线 | 免费在线观看国产 | 含羞草国产亚洲精品岁国产精品 | 精品少妇爆AV无码专区 | 精品午夜中文字幕熟女人妻在线 | 国产性夜夜春夜夜爽1A片 | 成人区精品一区二区不卡AV免费 | 欧美色图一区二区三区 | 久久毛片免费看一区二区三区 | 妖精视频一区二区免费 | 俄罗斯XBXBXB兽交 | gv手机在线观看 | 又爽又黄又粗又大免费视频 | 99日影院在线播放 | 久久久97丨国产人妻熟女 | 九九热只有精品 | 爱穿丝袜的麻麻3d漫画免费 | 偷上邻居熟睡少妇 | 国产精品69人妻无码久久 | 久久全国免费观看视频 | 99在线视频免费观看视频 | 狠狠色欧美亚洲狠狠色www | 精品国产人成亚洲区 | 欧美日韩亚洲综合2019 | 九九精品久久 | 国产亚洲精品久久久久 | 末成年美女黄网站色大片连接 | FREECHINESE东北女人真爽 free18sex性自拍裸舞 | 99久久国产综合精品国 | 我解开了岳的乳第一个女人 | 在线播放无码字幕亚洲 | 成人免费视频在线 | 第四色播日韩AV第一页 | 野花香在线观看免费高清播放视频 | 狼人无码伊人AV啪啪 | 高清欧美一区二区三区 | 欧美雌雄双性人交xxxx |