Ajax的XML,json,ajax中的json格式-12.30

Ajax的XML

1.請求的數據格式-XML

  • 客戶端如何構建XML格式的數據

  • 構建的數據類型 - 字符串類型

  • 字符串的內容要符合XML格式的語法要求

  • 服務器端如何接受符合XML格式的數據
    接收到的客戶端的請求數據 - 字符串類型,php集成了DOM的相關內容

    DOMDocument
    DOMElement
    DOMNode
    

    2.響應的數據格式-XML

  • 服務器端如何構建符合XML格式的數據

  • 設置服務器端的響應頭Content-Type值為text/xml
    header("Content-Type:text/xml");

  • 構建符合XML格式的數據內容
    DOMDocument對象的方法
    loadXML(符合XML格式的字符串)
    saveXML()方式進行響應

  • 客戶端如何接受XML格式的數據

  • 使用XMLHttpRequest對象的responseXML屬性接收

  • 接收到的就是XML DOM對象(不需要進行解析)

json

1.JSON - javascript object notation(JS原生支持)
2.json數據格式源于js
3.特點:

  • 易于程序員閱讀和編寫
  • 易于計算機解析和生成
  • json是目前網絡上使用最廣泛的數據格式之一
  • Array和Object
  • 支持的數據類型
  • 字符串、數值、布爾值、對象、數組、null

ajax中的json格式

1.請求格式為json

  • 客戶端向服務器端發送請求為json格式的數據

  • 構建符合JSON格式的字符串

  • 定義字符串時,保證里面使用雙引號,外面使用單引號

  • 服務器端接受json格式的數據

  • 使用json_decode()函數進行解析

  • json_decode($json,true);ture代表是否轉換為數組

2.響應格式為json

  • 服務器端向客戶發送響應為json格式的數據
  • 手工方式構建json格式的字符串
  • 使用json_encode()函數將php變量(數組),轉換成復合json格式的字符串
  • 客戶端接受json格式的數據
  • 使用XMLHttpRequest對象的responseText屬性接受
  • 然后使用eval函數進行轉換,如果使用()包裹,eval函數強制轉換為js代碼,
    var json = eval("("+data+")");

HTML(文本)、XML格式、JSON格式的優缺點

  • HTML: 簡單,但解析復雜
  • XML: 構建、解析復雜
  • JSON: 輕量級

jQuery中的ajax

1.封裝第一層 - 類似于原生ajax的用法

$ajax:
var data = {
  name:"jj",
  site:1
}
$.ajax({
  url:"myPhp04.php",
  type:"post",
  data:data,
  success:function(data,textStatus){
    console.log(textStatus);
    console.log(data);
  },
  error:function(){
  },
  dataType:"json",
})

2.封裝第二層 - 基于第一層再次封裝

  $().load(); 
  $.post();

3.封裝的第三層 - 特殊用法

  $.getScript(); - 動態讀取腳本(js代碼)
  $.getJson();  - 接收json格式數據

load(url,data,callback)方法

1.最簡單、局限性最大

  • url - 設置ajax的請求地址
  • data - 設置ajax的請求數據
    要求為key:value格式,其實就是js的對象格式
  • callback: ajax請求成功后的回調函數
    回調函數的參數就是服務器返回的數據

2.服務器響應的數據自動寫入調用load方法的屬性中
3.load()方法的請求類型

  • 沒有請求數據時,請求類型是GET
  • 發送請求數據時,請求類型是POST

4.load()方法接受服務器端的響應數據
是以字符串類型(HTML格式)來接受

get/post()方法

1.get(url,data,callback,type)

  • 參數
  • url - 設置ajax的請求地址
  • data - 設置ajax的請求數據
    要求為key:value格式,其實就是js的對象格式
  • callback: ajax請求成功后的回調函數
    回調函數的參數就是服務器返回的數據
  • type:設置服務器端響應的數據格式
    默認值為HTML,還可以為xml/json
  • 無論是否發送請求數據,請求類型都是GET
  • $.get()方法可以接受HTML/XML/JSON格式

2.post(url,data,callback,type)
使用方式跟get一模一樣

$.ajax(options)方法

1.options的格式是{key:value}
2.url:請求地址

  1. type:請求類型,默認為get

  2. async:是否異步,默認為true
    5.contentType POST方式發送數據的前提
    默認值為application/x-www-form-urlencoded
    6.data:請求數據,格式必須為key=value
    7.success:請求成功后的回調函數

     function(data,textStatus)
       data - 服務器響應的內容
       textStatus - 表示ajax請求的狀態,此時的值為success
    

8.error:請求失敗后的回調函數

    function(XMLHttpRequest,textStatus,errorThrown)
      XMLHttpRequest - ajax的核心對象
      errorThrown - 錯誤異常信息
      textStatus - 表示ajax請求的狀態
      error/timeout/notmodified

9.dataType:數據響應格式
HTML/XML/JSON

使用$.getScript(url,calback)動態讀取腳本

1.若JS代碼過多時,會影響HTML頁面加載的速度,如果已被加載的JS代碼并不是立即執行,只加載馬上執行的js代碼,會提交效率
2.參數

  • url - 讀取腳本的地址(本地或服務器)
  • calback - 回調函數

表單的Ajax異步提交 -

1.表單的序列化

  • serialize() 返回的是json字符串
    使用表單元素的name屬性值
    {key:value}

  • serializeArray() 返回的是json對象
    json對象由一個對象數組組成
    [obj1,obj2,obj3,...]

  • 注意:
    表單必須要有name屬性

  1. jQuery.form插件
  • 實現表單的異步提交,底層機制,還是使用正常的表單提交機制

  • 兩個核心方法 - 參數既是一個option參數

  • ajaxForm(options)方法
    ajaxForm()不能提交表單。在document的ready函數中,使用ajaxForm來為 AJAX提交表單進行準備。提交動作必須由submit開始

  • ajaxSubmit(option)方法
    ajaxSubmit()馬上由AJAX來提交表單。你可以在任何情況下進行該項提交。

  • 參數

  • target 服務器返回內容所存放的元素ID

  • beforeSubmit 提交前回調函數,如果返回false,則不提交

  • success 提交后的回調函數,一般有兩個參數responseText,statusText

  • url 默認是form的action,如果聲明,則覆蓋

  • type 默認是form的method,如果聲明,則覆蓋

  • dataType html(默認),xml,script,json….接受服務端返回的類型

  • clearForm 布爾值,成功提交后,是否清除所有表單元素值

  • resetForm 布爾值,成功提交后,是否重置所有表單元素值

  • timeout 限制請求時間,大于該時間后則跳出請求
    http://www.cnblogs.com/popzhou/p/4338040.html

3.表單異步提交的方式

  • 不使用submit按鈕,而是使用button按鈕,通過綁定click事件,實現提交
  • 表單的序列化
  • 表單的異步提交
  • (常用)依舊使用submit事件,在form元素中綁定onsubmit事件,在onsubmit事件的處理函數中要做如下事情
  • 表單的序列化
  • 表單的異步提交
  • 組織表單的默認行為

getJson()方法 - 可以實現跨域提交

1.什么叫做跨域

  • 跨域:完全跨域 - IP不同

  • 域名:

  • 頂級域名 - http://www.baidu.com

  • 二級域名 - http://www.baidu.com/kongjian

  • 萬維網協議:

  • 默認是不允許跨域請求的

  • 服務器那邊返回的是一個函數字符串

      $.getJson("url?callback=?",function(data){
     })
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,460評論 6 538
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,067評論 3 423
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,467評論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,468評論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,184評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,582評論 1 325
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,616評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,794評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,343評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,096評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,291評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,863評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,513評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,941評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,190評論 1 291
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,026評論 3 396
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,253評論 2 375

推薦閱讀更多精彩內容