jQuery使用ajax方法解析返回的json數(shù)據(jù)功能示例
本文實(shí)例講述了jQuery使用ajax方法解析返回的json數(shù)據(jù)功能。分享給大家供大家參考,具體如下:
最近在用jQuery的ajax方法傳遞接收json數(shù)據(jù)時發(fā)現(xiàn)一個問題,那就是返回的data數(shù)據(jù),有時候可以直接作為json數(shù)據(jù)使用,可有時候又不行。查了些資料,解釋如下:
$.ajax({ url: ajaxurl, type: "POST", success: function(data){ //假設(shè)返回的json數(shù)據(jù)里有status及info2個屬性 //有時候可以直接ajaxobj.status或者ajaxobj["status"]去訪問 //但有時候,卻要通過eval()或者 $.parsejson();才可以通過ajaxobj.status訪問,而且這種情況下,需要是complete而不是success ajaxobj=eval("("+data+")"); //或者$.parsejson() //var ajaxobj = $.parsejson(data); if(ajaxobj.status=="0") { alert("請登陸."); } else if(ajaxobj.status=="1")//未綁定微博 { alert(ajaxobj.info); } return true; }, error:function(ajaxobj) { if(ajaxobj.responseText!='') alert(ajaxobj.responseText); } });
先說明第一種情況:
能夠直接 data.屬性名訪問的情況,服務(wù)器端代碼一定是直接return的一個常量字符串。
什么是常量字符串呢,常量字符串就是指直接用“”組成的字符串,沒有定義String 變量直接把一串“”print到前臺的情況,就可以直接data.屬性名訪問,而且jquery端只要寫success就可以拿到。
下面是造成要eval并且不能進(jìn)入success的原因:
這種情況是因?yàn)榉?wù)器端向外print的時候是一個String對象,通常此類問題在我的代碼里是因?yàn)楹笈_json比較復(fù)雜,在組織的時候我用到了StringBuffer,然后最后print的時候print的是StringBuffer對象的toString,所以就相當(dāng)于print了一個String對象
這種情況下jquery的ajax方法就不會進(jìn)入success方法,只能用complete接收,并且想要解析data里的json數(shù)據(jù)的話,必須對data.responseText進(jìn)行eval ()或者 $.parsejson();
除此兩點(diǎn),還有需要注意的是,如果你使用的是jq1.4,那么他對json的格式有著更嚴(yán)格的要求,所有的key和屬性都要用雙引號標(biāo)注起來,雖然key不用雙引號原生的js是允許的,但是jq1.4似乎有這個要求。
以上是我個人的想法跟理解,若有不同見解歡迎指教.
PS:關(guān)于json操作,這里再為大家推薦幾款比較實(shí)用的json在線工具供大家參考使用:
在線JSON代碼檢驗(yàn)、檢驗(yàn)、美化、格式化工具:
http://tools.jb51.net/code/json
JSON在線格式化工具:
http://tools.jb51.net/code/jsonformat
在線XML/JSON互相轉(zhuǎn)換工具:
http://tools.jb51.net/code/xmljson
json代碼在線格式化/美化/壓縮/編輯/轉(zhuǎn)換工具:
http://tools.jb51.net/code/jsoncodeformat
在線json壓縮/轉(zhuǎn)義工具:
http://tools.jb51.net/code/json_yasuo_trans
C語言風(fēng)格/HTML/CSS/json代碼格式化美化工具:
http://tools.jb51.net/code/ccode_html_css_json
更多關(guān)于jQuery相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《jquery中Ajax用法總結(jié)》、《jQuery操作json數(shù)據(jù)技巧匯總》、《jQuery form操作技巧匯總》、《jQuery常用插件及用法總結(jié)》、《jQuery擴(kuò)展技巧總結(jié)》、《jQuery表格(table)操作技巧匯總》及《jquery選擇器用法總結(jié)》
希望本文所述對大家jQuery程序設(shè)計(jì)有所幫助。
- JS解析json數(shù)據(jù)并將json字符串轉(zhuǎn)化為數(shù)組的實(shí)現(xiàn)方法
- JavaScript中解析JSON數(shù)據(jù)的三種方法
- JS中Json數(shù)據(jù)的處理和解析JSON數(shù)據(jù)的方法詳解
- Jquery解析json數(shù)據(jù)詳解
- JavaScript處理解析JSON數(shù)據(jù)過程詳解
- javascript解析json數(shù)據(jù)的3種方式
- json數(shù)據(jù)傳到前臺并解析展示成列表的方法
- javascript對JSON數(shù)據(jù)排序的3個例子
- js解析與序列化json數(shù)據(jù)(二)序列化探討
- javascript 循環(huán)讀取JSON數(shù)據(jù)的代碼
- JavaScript解析JSON數(shù)據(jù)示例
相關(guān)文章
jQuery移動端跑馬燈抽獎特效升級版(抽獎概率固定)實(shí)現(xiàn)方法
這篇文章主要介紹了jQuery移動端跑馬燈抽獎特效升級版(抽獎概率固定)實(shí)現(xiàn)方法,涉及jQuery數(shù)值運(yùn)算及條件判斷等相關(guān)操作技巧,需要的朋友可以參考下2019-01-01jQuery+html5實(shí)現(xiàn)div彈出層并遮罩背景
今天在項(xiàng)目中用到了一個很好的div彈出層效果,jQuery+html5實(shí)現(xiàn)div彈出層并遮罩背景,效果非常棒,拿出來和大家一起分享!2015-04-04使用jQuery操作HTML的table表格的實(shí)例解析
這篇文章主要介紹了使用jQuery操作HTML的table表格的實(shí)例解析,包括用jQuery獲取表格總行數(shù)的小技巧,需要的朋友可以參考下2016-03-03如何用jQuery實(shí)現(xiàn)ASP.NET GridView折疊伸展效果
我們今天就一個具體的需求進(jìn)行分析,引出如何用jQuery實(shí)現(xiàn)ASP.NET GridView折疊伸展效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2015-09-09jQuery 操作option的實(shí)現(xiàn)代碼
js清空option之前清空option ,我的做法是遍歷現(xiàn)有option,將其每個子元素都置空即可。2011-03-03