精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

談JSON在Ajax中的使用

開發(fā) 前端 后端
我想對于JSON和Ajax大家都不陌生,本文問大家介紹,JSON在Ajax中是怎么使用的,希望對你有幫助,一起來看。

JSON是一種輕量級的數(shù)據(jù)交換格式。易于人閱讀和編寫,同時也易于機(jī)器解析和生成。AJAX是一種用于創(chuàng)建更好更快以及交互性更強(qiáng)的 Web 應(yīng)用程序的技術(shù)。之前也曾介紹過在PHP語言中使用JSON的文章,大家也可以看看,供參考。

雖然XML在Ajax運(yùn)行中具有舉足輕重的地位,但JavaScript開發(fā)人員很快就對它失去了興趣。在JavaScript中操作XML存在嚴(yán)重的跨瀏覽器問題,而且從XML結(jié)構(gòu)中提取數(shù)據(jù)也需要涉及遍歷DOM文檔,而這些操作都需要編寫大量的代碼。Douglas Crockford發(fā)明了一種叫JSON(JavaScript Object Notation)的數(shù)據(jù)格式卻能夠創(chuàng)建與XML相同的數(shù)據(jù)結(jié)構(gòu)。JSON的基礎(chǔ)是JavaScript語法中一個子集,特別是對象和數(shù)組字面量。JSON的設(shè)計(jì)意圖是在服務(wù)器構(gòu)建格式化數(shù)據(jù),然后再將數(shù)據(jù)發(fā)送給瀏覽器。

由于JSON在JavaScript中相當(dāng)于對象和數(shù)組,轉(zhuǎn)換速度快,而且便于在JavaScript代碼中訪問,JSON在Ajax通信中越來越受開發(fā)人員的追捧。Web開發(fā)社區(qū)已經(jīng)為幾乎所有主流的語言都開發(fā)了JSON解析器和序列化器,使得通過服務(wù)器輸出和使用JSON數(shù)據(jù)變得極為容易。

Douglas Crockford自己也維護(hù)著一個針對JavaScript的JSON序列化器/解析器,下載地址為http://www.json.org/js.html,可以去下載那個JavaScript文件,且該文件在所有瀏覽器都能正常使用。此外,IE8中包含了Crockford解析器的原生版本。

在Crockford的這個JSON庫中,有一個全局對象,這個對象有兩個方法:parse()和stringify()。其中,parse()方法接受兩個參數(shù):JSON文本和一個可選的過濾函數(shù)。在傳入的文本是有效的JSON的情況下,parse()方法會返回傳入數(shù)據(jù)的一個對象表示。下面是使用parse()方法的示例:

 

  1. var object=JSON.parse("()"); 

與直接使用eval()不同的是這里不需要為傳入的文本加圓括號。

第二個參數(shù)是一個函數(shù),這個函數(shù)以一個JSON鍵和值作為參數(shù)。要想讓作為參數(shù)傳入的的鍵出現(xiàn)有結(jié)果對象中,該函數(shù)必須返回一個值。它的返回值將成為結(jié)果對象中與指定鍵關(guān)聯(lián)的值,因此也就為我們重寫默認(rèn)的解析機(jī)制提供了機(jī)會。換句話說,在這個函數(shù)中針對某個鍵返回undefined,就會從結(jié)果對象中移除該鍵。如下面的例子所示:

  1. var jsontext="{"\name\":\"WangGang\",\"age\":29,\"author\":true }";  
  2. var object=JSON.parse(jsontext,function(key,value){  
  3. switch(key){  
  4. case "age"return value+1;  
  5. case "author"return undefined;  
  6. defaultreturn false;  
  7. }  
  8. });  
  9. alert(object.age) //30  
  10. alert(object.author) //undefined 

 

在以上代碼中,過濾函數(shù)會為每個"age"鍵的值加1,會移除數(shù)據(jù)中的"author"鍵,其他值則會原樣返回。于是,結(jié)果對象中的age屬性值就變成了30,但是卻沒有author屬性,這種解析功能經(jīng)常用于處理服務(wù)器返回的數(shù)據(jù)。假設(shè)addressbook.php會以下面的格式返回JSON數(shù)據(jù):

  1. {  
  2. {  
  3. "name":"WangMeng",  
  4. "email":"wangmeng@some-domain-name.com" 
  5. },{  
  6. "name":"LinTao",  
  7. "email":"linTao@some-domain-name.com" 
  8. },{  
  9. "name":"Jim",  
  10. "email":"jim@some-domain-name.com" 
  11. }  

可以發(fā)送一個Ajax請求取得以上數(shù)據(jù),然后在客戶端使用下列代碼生成相應(yīng)的<ul/>元素:

  1. var xhr=createXHR();  
  2. xhr.onreadystatechange=function(){  
  3. if(xhr.readyState == 4){  
  4. if((xhr.status >= 200 && xhr.status < 300)|| xhr.status == 304){  
  5. var contacts=JSON.parse(xhr.responseText);  
  6. var list=document.getElementById("contacts");  
  7. for(var i=0,len=contacts.length;i<len;i++){  
  8. var li=document.createElement("li");  
  9. li.innerHTML="<a href=\"mailto:" + contacts[i].email + "\">" + contacts[i].name + "</a>";  
  10. list.appendChild(li);  
  11. }  
  12. }  
  13. xhr.open("get","addressbook.php",true);  
  14. xhr.send(null);  
  15. }  
  16. }; 

以上代碼從服務(wù)器取得了JSON字符串,然后將它解析成了JavaScript數(shù)組,得到數(shù)組后,通過迭代遍歷其中的每個對象,很容易就可以將相應(yīng)的值插入到DOM中。具體來說,<ul/>元素會包含一些<li/>元素,而每個<li/>元素則會包含一個鏈接,點(diǎn)擊可以向一個人發(fā)送電子郵件。

JSON同樣也是向服務(wù)器發(fā)送數(shù)據(jù)的瀏覽格式。發(fā)送數(shù)據(jù)時,一般會把JSON放到POST元素請求主體中,而JSON對象的stringify()方法正是為此而設(shè)計(jì)的。這個方法接受3個參數(shù):要序列化的對象,可選的替換函數(shù)(用于替換未接受的JSON值)和可選的縮進(jìn)說明符(可以是每個級別縮進(jìn)的空格數(shù),也可是用來縮進(jìn)的字符)。默認(rèn)情況下,stringify()返回未經(jīng)縮進(jìn)的JSON字符串,下面是一個例子:

  1. var contact={  
  2. name:"WangMeng",  
  3. email:"wangmeng@some-domain.com" 
  4. };  
  5. var jsontext=JSON.stringify(contact);  
  6. alert(jsontext); 

這個例子中的警告框會顯示下列未經(jīng)縮進(jìn)的字符串:
(\"name\":\"wangmeng\",\"email\":\"wangmeng\":\wangment@some-domain.com\)

由于并不是所有JavaSrcipt值都可以使用JSON表示,因此結(jié)果中只會包含那些正式得到支持的值。例如,函數(shù)和undefined值無法通過JSON表示,包含它們的任何鍵默認(rèn)都將被移除。要改變這個默認(rèn)的行為,可以在第二個參數(shù)的位置傳入一個函數(shù)。在序列化過程 中每當(dāng)遇到一個不支持的數(shù)據(jù)類型時,該函數(shù)就會在被序列化的對象中作用域中運(yùn)用,其參數(shù)是相應(yīng)的鍵和值。

對于JSON支持的數(shù)據(jù)類型,序列化過程中不會調(diào)用這個函數(shù),這些類型包括:字符串、數(shù)值、布爾值、null、對象、數(shù)組和Date。來看下面的例子:

  1. var jsontext=JSON.stringify([new Function()],function(key,value){  
  2. if(value instanceof Function){  
  3. return "(function)";  
  4. }else{  
  5. return value;  
  6. }  
  7. });  
  8. alert(jsontext); //"(function)" 

這個例子試圖序列化一個包含函數(shù)的數(shù)組。當(dāng)遇到函數(shù)值時,第二個參數(shù)(即過濾函數(shù))會將它轉(zhuǎn)換為字符串"(function)",該字符串將出現(xiàn)在最終結(jié)果中。

使用POST請求并將JSON文本傳遞給send()方法,可以將JSON數(shù)據(jù)發(fā)送給服務(wù)器。來看下面的例子:

  1. var xhr=createXHR();  
  2. var contact={  
  3. name:"wangmeng",  
  4. email:"wangmeng@some-domain.com" 
  5. };  
  6. xhr.onreadystatechange=function(){  
  7. if(xhr.readyState == 4){  
  8. if((xhr.status <= 200 && xhr.status < 300) || xhr.status == 304){  
  9. alert(xhr.responseText);  
  10. }  
  11. }  
  12. };  
  13. xhr.open("post","addcontact.php",true);  
  14. xhr.send(JSON.stringify(contact)); 

這個例子是要將新聯(lián)系人信息保存到服務(wù)器,因此要將數(shù)據(jù)發(fā)送給addcontact.php文件。在根據(jù)新聯(lián)系人信息構(gòu)建好contact對象后,又將它序列化為JSON數(shù)據(jù)并傳遞給send()方法。服務(wù)器上的PHP頁面負(fù)責(zé)將接受到的JSON數(shù)據(jù)解析回原來的格式,以便服務(wù)器端代碼能夠理解,同時還會向?yàn)g覽器發(fā)送響應(yīng)。

本文地址:http://www.yiiyaa.net/1378

【編輯推薦】

  1. 理解JSON:3分鐘課程輕松搞定
  2. JSONP跨域原理和jQuery.getJSON用法
  3. 在PHP語言中使用JSON
  4. Jackson框架輕易轉(zhuǎn)換JSON
  5. Ajax和WEB服務(wù)數(shù)據(jù)格式:JSON JSONP
責(zé)任編輯:于鐵 來源: yiiyaa.net
相關(guān)推薦

2009-01-16 13:17:16

AjaxASP.NET.NET

2020-12-03 07:43:03

JS Ajax JavaScript

2009-06-05 14:59:31

Eclipse中配置T

2009-07-07 09:41:02

異步ServletAJAX

2010-01-06 11:05:35

JSON

2009-02-27 16:57:51

AJAX判斷請求

2024-05-10 08:36:40

Go語言對象

2009-03-13 09:48:33

ASP.NETAjaxJQuery

2009-07-30 12:19:32

ASP.NET中使用A

2009-01-08 10:20:56

AutoCompletAjaxASP.NET

2010-06-17 10:22:47

PHP

2009-01-03 08:41:51

Ajax無框架的AjaxASP.NET

2009-06-15 16:29:42

JSONAJAX

2020-06-30 08:23:00

JavaScript開發(fā)技術(shù)

2011-05-25 13:22:05

PHPJSON

2021-03-25 09:58:22

鴻蒙HarmonyOS應(yīng)用開發(fā)

2023-10-25 14:51:38

MySQL數(shù)據(jù)庫JSON

2011-06-16 14:38:18

JavaScript事件委托

2014-07-22 09:01:53

SwiftJSON

2009-04-09 15:40:01

JSONJavaScript枚舉
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

亚洲欧美另类自拍| 亚洲一区二区三区视频在线播放| 国产精品久久久久一区二区 | 在线免费观看一级片| 亚洲成人一区| 日韩成人av在线| 97超碰成人在线| 蜜桃视频www网站在线观看| 国产日韩成人精品| 古典武侠综合av第一页| 无码人妻精品一区二区三区不卡| 91精品国产乱码久久久久久久| 日韩成人黄色av| 日本中文字幕二区| 成人美女视频| 亚洲精品国产精品乱码不99| 久久综合九色综合网站| 国产欧美日韩综合精品一区二区三区 | 精品系列免费在线观看| 2019中文字幕全在线观看| 亚洲一区电影在线观看| 午夜欧洲一区| 日韩欧美国产麻豆| 国产视频手机在线播放| 黄色aa久久| 日韩美女视频19| 欧美精品七区| 色婷婷av一区二区三| 精品一区二区三区在线播放| 国产999精品久久久影片官网| 青青草国产在线观看| 日韩欧美精品综合| 亚洲跨种族黑人xxx| 成人欧美精品一区二区| 亚洲图片小说区| 欧美亚男人的天堂| 3d动漫一区二区三区| 在线观看男女av免费网址| 国产精品网曝门| 欧美午夜视频在线| 婷婷伊人综合中文字幕| 成人免费视频视频| 91免费视频国产| 91精品国产乱码久久| 日韩在线一二三区| 国产成人+综合亚洲+天堂| 日日夜夜综合网| 亚洲激情午夜| 国内自拍欧美激情| 免费观看一级视频| 欧美日韩第一区| 欧美日韩高清在线观看| 九九精品视频免费| 亚洲欧美综合久久久| 色综合伊人色综合网站| 任你操精品视频| 97色伦图片97综合影院| 久久精品成人一区二区三区 | 精品国产一区二区三区久久久樱花| 亚洲二区在线播放视频| 免费a v网站| 狼人精品一区二区三区在线| 亚洲高清av在线| jizz欧美性20| 青青草久久爱| 亚洲欧美日韩国产中文| 一色道久久88加勒比一| 欧美日韩一二三四| 日韩中文字幕在线播放| 免费国产羞羞网站美图| 亚洲欧美亚洲| 91精品国产乱码久久久久久久久| 天堂网av手机版| 老牛嫩草一区二区三区日本 | 国产精品2区| 欧美一区二区国产| 99久久久无码国产精品性波多| 极品一区美女高清| 亚洲一级片在线看| 强制高潮抽搐sm调教高h| 伊人成综合网| 97高清免费视频| 手机av免费观看| 久久精品99国产精品| 亚洲一区中文字幕在线观看| 黑人乱码一区二区三区av| 97se狠狠狠综合亚洲狠狠| 欧美日韩在线观看一区| 日本综合在线| 午夜欧美视频在线观看| av无码精品一区二区三区| 亚洲我射av| 亚洲精品mp4| 性爱在线免费视频| 在线播放不卡| 国产精自产拍久久久久久| 精品国产伦一区二区三| 久久亚洲免费视频| av电影一区二区三区| 黄色在线网站噜噜噜| 欧美日韩精品三区| 性欧美18—19sex性高清| jlzzjlzz亚洲女人| 欧美国产日韩免费| 这里只有精品999| 成人精品高清在线| 亚洲在线视频一区二区| 理论片午夜视频在线观看| 欧美电影一区二区| 青青草视频成人| 欧美精品国产一区| 国产精品美腿一区在线看| 免费看av毛片| 亚洲天天做日日做天天谢日日欢| 久久精品成人动漫| 欧美污视频久久久| 成人女同在线观看| 欧美日韩www| 日本一区二区三区网站| 中文一区一区三区免费在线观看| 国产成人精品电影| 日本高清视频www| 亚洲美女少妇撒尿| 日本在线观看免费视频| 久久香蕉网站| 欧美成人亚洲成人| 国产一区二区在线视频聊天| 94色蜜桃网一区二区三区| 国产在线无码精品| 亚洲国产综合在线观看| 国产亚洲视频在线观看| 色网站在线播放| 成人免费看视频| 4444在线观看| 警花av一区二区三区| 最近更新的2019中文字幕| 波多野结衣家庭主妇| 97精品视频在线观看自产线路二| 久久久99精品视频| 久久久久久爱| 久久久电影免费观看完整版| 在线视频免费观看一区| 国产欧美综合在线| 欧美一级黄色影院| 欧美日韩精品在线一区| 国产精品aaaa| aaa在线观看| 欧美日韩国产免费一区二区 | 欧亚精品一区| 欧美一级淫片丝袜脚交| 午夜影院免费视频| 精品久久在线播放| 亚洲国产精品成人综合久久久| 亚洲麻豆视频| 久久偷看各类wc女厕嘘嘘偷窃 | 人妻丰满熟妇aⅴ无码| 99国内精品| 欧美日本韩国一区二区三区| 日韩高清在线| 中文字幕av一区二区三区谷原希美| 毛片在线免费播放| 国产精品久久毛片| 三日本三级少妇三级99| 韩日成人在线| 精品国产一区二区三区麻豆免费观看完整版| 欧美人与性动交α欧美精品济南到 | 欧美少妇性生活视频| 国产一区二区三区日韩精品| 国产精品久久综合av爱欲tv| 香蕉视频网站在线观看| 91精品国产色综合久久不卡电影| 国产黄色小视频网站| 国产91精品在线观看| 免费一级特黄特色毛片久久看| 欧美一区 二区| 日韩免费在线看| 日本不卡视频| 精品88久久久久88久久久 | 欧美日韩视频第一区| 日韩三级久久久| 国产成人精品亚洲午夜麻豆| 99精品在线免费视频| 日韩av片子| 成人欧美一区二区三区黑人免费| 狼人综合视频| 久久精品久久久久| 日本国产在线观看| 欧美亚洲高清一区二区三区不卡| 久久久久久久久毛片| 久久综合九色综合欧美98| 中文字幕网av| 亚洲狼人精品一区二区三区| 日韩国产欧美精品| 日日夜夜精品视频| 国产精品高清免费在线观看| 成人在线免费看片| 亚洲精品视频中文字幕| 国产精品-色哟哟| 亚洲成人你懂的| 香蕉成人在线视频| 91啪亚洲精品| 日本中文字幕有码| 美女爽到高潮91| www.中文字幕在线| 亚洲精品va| 色综合电影网| 日本亚洲不卡| 91久色国产| 欧美成人家庭影院| 欧美一区二区视频97| caopon在线免费视频| 国产亚洲精品久久久久动| 熟妇人妻一区二区三区四区 | 亚洲一二三四区| 99精品中文字幕| www日韩大片| 人妻激情偷乱频一区二区三区| 免费看欧美女人艹b| 国产精品va无码一区二区| 欧美 日韩 国产 一区| 日本精品视频一区| 玖玖玖免费嫩草在线影院一区| 亚洲字幕在线观看| 久久亚洲国产精品尤物| 日本在线精品视频| 成人三级高清视频在线看| 久久伊人精品一区二区三区| av中文字幕在线| 亚洲精品视频网上网址在线观看| 内射无码专区久久亚洲| 欧美一区二区成人| 国产又黄又猛又爽| 欧美老肥妇做.爰bbww| 波多野结衣在线观看一区| 精品女厕一区二区三区| 免费观看一级视频| 一卡二卡三卡日韩欧美| 中文字幕电影av| 亚洲婷婷国产精品电影人久久| 日本视频在线免费| 国产精品网站一区| 五月婷婷婷婷婷| 国产欧美综合色| 欧洲美熟女乱又伦| 国产欧美日韩亚州综合 | 国产精品久久福利| 欧美日韩国产一二三区| 国产精品福利一区| 三级黄色录像视频| 亚洲欧美福利一区二区| 综合五月激情网| 亚洲精品老司机| 青青操视频在线播放| 亚洲综合色婷婷| 国产一级中文字幕| 亚洲超丰满肉感bbw| 日韩精品在线不卡| 婷婷一区二区三区| 久久夜色精品国产噜噜亚洲av| 欧美午夜影院在线视频| 99久久久无码国产精品免费蜜柚| 91国产精品成人| 在线不卡免费视频| 欧美一区二区三区在线电影| 国产肥老妇视频| 精品国免费一区二区三区| 日本高清视频在线| 亚洲图片欧美日产| 国产淫片在线观看| 欧美日韩第一视频| 午夜久久中文| 国产精品一二区| 麻豆久久一区| 精品国产综合久久| 欧美日韩国产传媒| xxxxxx在线观看| 伊人精品在线| 97公开免费视频| 精一区二区三区| 91传媒理伦片在线观看| 99re热视频精品| 久久久久久久麻豆| 亚洲午夜精品在线| 国产成人自拍偷拍| 日韩欧美中文字幕一区| 亚洲日本在线播放| 精品国内自产拍在线观看| 久草在线视频福利| 国产精品扒开腿爽爽爽视频| 国产高清视频一区二区| 精品久久精品久久| 色777狠狠狠综合伊人| 免费高清一区二区三区| 日韩av电影天堂| 久草福利在线观看| 国产三级精品视频| 久久久久久久中文字幕| 在线免费视频一区二区| www国产在线| 在线观看欧美日韩国产| 不卡一本毛片| 国产欧美在线视频| 日本国产精品| 国产91在线亚洲| 日韩 欧美一区二区三区| av不卡中文字幕| 亚洲欧美综合色| 无码人妻精品一区二区50| 精品国产91洋老外米糕| 男人的天堂在线视频免费观看| 8x拔播拔播x8国产精品| 日韩免费一级| 自拍偷拍99| 免费人成网站在线观看欧美高清| 欧美成人三级伦在线观看| 成人免费小视频| 超碰在线观看91| 亚洲国产精品va在线| 在线免费观看a视频| 国产乱肥老妇国产一区二 | 日本午夜免费一区二区| 欧美亚洲精品日韩| 亚洲免费高清| 亚洲熟女乱综合一区二区| 1024国产精品| 一区二区的视频| 揄拍成人国产精品视频| 欧美成人免费电影| 国产区一区二区三区| 欧美一区网站| 婷婷激情小说网| 亚洲欧洲性图库| 在线观看国产小视频| 一区二区三区动漫| 日韩电影免费看| 久久本道综合色狠狠五月| 怡红院精品视频在线观看极品| 欧美体内she精高潮| 中文字幕在线不卡| 亚洲视频在线免费播放| 在线日韩日本国产亚洲| 国产综合av| 日本成人三级| 日韩电影一区二区三区四区| 国产一二三四五区| 欧美性猛交xxxx久久久| 四虎在线免费看| 欧美最猛性xxxxx(亚洲精品)| 麻豆一区二区| 国产在线观看福利| 久久网站最新地址| 高潮毛片又色又爽免费 | 久久99精品久久久久久三级 | 日韩在线无毛| 日本久久久a级免费| 免费av一区二区三区四区| 国产精品亚洲a| 日本一二三四高清不卡| 中文字幕永久免费视频| 精品国产一区二区三区四区在线观看| 国精品产品一区| 四虎影院一区二区| 国产一区二区在线视频| 激情综合五月网| 亚洲精品美女久久久久| 男人皇宫亚洲男人2020| 日韩中文字幕一区| 另类小说一区二区三区| 波多野结衣不卡视频| 欧美大片一区二区三区| 麻豆免费版在线观看| 欧美日韩在线一二三| 美女一区二区视频| 黄页网站免费观看| 日韩精品在线免费观看视频| 日韩经典一区| 超级碰在线观看| www久久精品| 国产在成人精品线拍偷自揄拍| 欧美黑人性视频| 日韩欧美影院| 91网址在线观看精品| 亚洲成人动漫av| eeuss影院www在线播放| 97碰碰视频| 日日骚欧美日韩| 黄色一级视频在线观看| 亚洲片国产一区一级在线观看| 欧美黄色a视频| 国产伦精品一区二区三区四区视频_| 国产亚洲精品福利| www.热久久| 国产精品福利观看| 国户精品久久久久久久久久久不卡| 黄色正能量网站| 日韩亚洲欧美一区二区三区| 在线观看的黄色| www国产免费| 亚洲国产成人在线| 熟妇高潮一区二区三区|