上一篇講了Ajax請求數(shù)據(jù)text類型,text和html都是處理比較簡答的數(shù)據(jù),而在編程過程中使用Ajax調(diào)用數(shù)據(jù)的時(shí)候,難免要進(jìn)行邏輯的處理,接受的數(shù)據(jù)也變的復(fù)雜比如數(shù)組類型的數(shù)據(jù),這時(shí)候就需要使用JSON數(shù)據(jù)類型進(jìn)行處理,今天就說說,JSON數(shù)據(jù)請求過程中的一些細(xì)節(jié):
腳本之家友情提醒本文所需工具和原料如下:
wamp或lamp環(huán)境、jquery.js、編輯器
具體方法/步驟請看下面:
1.創(chuàng)建基本的文件結(jié)構(gòu)json_ajax.html和json_ajax.php,下載jquery.js,如圖:
2.如圖分別編寫json_ajax.html和json_ajax.php文件的編碼:
3.分別在w(l)amp環(huán)境下運(yùn)行json_ajax.html和json_ajax.php,運(yùn)行結(jié)果如圖:
這個(gè)運(yùn)行的結(jié)果應(yīng)該是正常的,理解上沒有困難的,繼續(xù)向下看,如果這里理解困惑,就沒必要在繼續(xù)閱讀的必要了。
4.經(jīng)過源碼和運(yùn)行結(jié)果的分析,知道了在json_ajax.html中設(shè)置了按鈕的點(diǎn)擊事件,點(diǎn)擊按鈕,正常的運(yùn)行結(jié)果如下圖;
若沒有正常的顯示,可參考我的《jQuery的Ajax之調(diào)試》
5.第4步結(jié)果分析:
console.log(data),直接將json_ajax.php返回的結(jié)果返回,就是json字符串;
console.log(eval('['+data+']')),這樣做的目的是將json_ajax.php返回的json字符串轉(zhuǎn)換成對象。
‘對象'在PHP里面是區(qū)別于過程的,但是在JS中,所有的數(shù)據(jù)都是對象,或許現(xiàn)在有點(diǎn)明白了,為什么要將json字符串轉(zhuǎn)換成對象了;在js中處理對象更方便,就像在PHP中處理數(shù)據(jù)的時(shí)候,首先想到的是數(shù)組(array)一樣。
6.細(xì)節(jié)總結(jié):
1.php返回的必須是json,即是需要將數(shù)據(jù)用json_encode()處理;
2.ajax接受數(shù)據(jù)之后,需要eval()處理,里面'['+data+']'可以用'('+data+')';
3.console.log()可以使用alert()代替;
4.在此主要是過程思路,一旦接收到data數(shù)據(jù),就可以按需求進(jìn)行邏輯處理了。
以上通過圖文并茂的方式給大家展示了Ajax異步請求JSon數(shù)據(jù),希望大家喜歡。
您可能感興趣的文章:- jquery的ajax異步請求接收返回json數(shù)據(jù)實(shí)例
- SpringMVC環(huán)境下實(shí)現(xiàn)的Ajax異步請求JSON格式數(shù)據(jù)
- ajax 同步請求和異步請求的差異分析
- ajax異步請求詳解
- Vue form 表單提交+ajax異步請求+分頁效果
- AJAX實(shí)現(xiàn)簡單的注冊頁面異步請求實(shí)例代碼
- dojo學(xué)習(xí)第二天 ajax異步請求之綁定列表
- ajax的工作原理以及異步請求的封裝介紹
- 基于JQuery的$.ajax方法進(jìn)行異步請求導(dǎo)致頁面閃爍的解決辦法
- 四步輕松實(shí)現(xiàn)ajax發(fā)送異步請求