校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > Ajax的使用代碼解析

Ajax的使用代碼解析

熱門標簽:立陶宛地圖標注 電銷機器人 長春 地圖標注推銷坑人 大眾點評400電話怎么申請 怎樣在地圖標注文字 河間市地圖標注app 中國地圖標注不明確情況介紹表 上海企業外呼系統價錢 東平縣地圖標注app

Ajax 簡介

Ajax被認為是(Asynchronous(異步) JavaScript And Xml的縮寫)。現在,允許瀏覽器與服務器通信而無須刷新當前頁面的技術都被叫做Ajax.

同步是指:發送方發出數據后,等接收方發回響應以后才發下一個數據包的通訊方式。 

異步是指:發送方發出數據后,不等接收方發回響應,接著發送下個數據包的通訊方式 。

通常不用刷新網頁而與服務器通訊的方法:

  • Flash 框架
  • Frameset:如果使用一組框架構造了一個網頁,可以只更新其中一個框架,而不必驚動整個頁面
  • XMLHttpRequest:該對象是對 JavaScript 的一個擴展,可使網頁與服務器進行通信。是創建 Ajax 應用的最佳選擇。實際上通常把 Ajax 當成XMLHttpRequest(XHR) 對象的代名詞

ajax基本使用

  ajax在我們的開發中是必須使用的一個技術,ajax即異步的javascript和xml但是現在我們通常使用json來完成數據的交互,ajax職責很單一就是數據的交互,發送數據接收數據是它的核心功能也是唯一的功能。

  ajax的實現依賴XMLHttpRequest,它的基本使用如下:

var xhr;
window.XMLHttpRequest?xhr = new XMLHttpRequest():xhr = new ActiveXObject("Microsoft.XMLHTTP");
xhr.open("get","demo!register.action?name=ztage=23",true);
xhr.send(null);
xhr.onreadystatechange = function(){
  if(xhr.readyState==4xhr.status==200){
   alert(JSON.parse(xhr.responseText));
  }
}

  ajax的職責就是發送數據和接收數據我們基本使用流程為:

  1.獲取一個XMLHttpRequest對象

  2.發送數據

  3.接收處理服務器返回的數據

  根據上面的步驟來實現一個異步請求數據的過程,首先獲取一個xhr對象,在現代瀏覽器中我們可以直接通過實例化來獲取一個xhr對象:var xhr = new XMLHttpRequest();在IE5、IE6中我們必須使用ActiveXObject來獲取xhr對象:var xhr = new ActiveXObject("Microsoft.XMLHTTP")。

  此時我們已經得到了xhr對象接下來就是發送數據,通過xhr.open()方法來執行發送數據的方式,xhr.open()可以接收5個參數,我們經常使用的是前三個:

xhr.open(arg1,arg2,arg3)

  arg1表示請求數據的方式一般為get或者post

  arg2表示請求的服務器地址

  arg3表示本次請求是同步還是異步,ajax的突出特點就是異步所以我們一般都是使用異步的方式第三個參數設置為true(true表示進行異步請求false表示進行同步請求)

  xhr.open()方法只是準備一個請求,在調用open之后并不會和服務器進行通訊,而是在調用send()函數之后才會和服務器開始通訊,send()函數的參數將作為請求體發送到服務端。如果我們在open()函數中指定請求的方式為get通常我們將send()設置為xhr.send(null),如果我們希望通過請求體發送數據則要將open()函數的請求方式設置為post同時將我們需要發送的數據作為send()函數的參數:xhr.send(param),在調用send()函數之后,和服務器的通訊就開始了。

  對xhr的所有的設置都應該在send()函數之前設置好:

 xhr.open(...);
 xhr.setRequestHeader(...);
 xhr.overrideMimeType(...);
 xhr.onreadystatechange = function(){...};
 xhr.send(...);

   但是由于xhr.onreadystatechange是一個事件,所以其放在send()之后也是可以執行的,出于易讀性我們一般都將對xhr的設置放在send()函數之前。

  在send()之后可以通過xhr.readyState和xhr.status的來監測本次請求的狀態,如果滿足xhr.readyState==4xhr.status==200則本次請求成功:

在請求成功時我們可以通過xhr.responseText來獲取服務器返回的數據,需要注意xhr.responseText是一個字符串。

ajax常用API

  上面的請求過程是一個最基本的請求過程xhr對象還有幾個經常使用的方法分別為xhr.abort()、xhr.setRequestHeader()、xhr.overrideMimeType()。

  xhr.abort():終止一個請求,直接調用即可不需要設置參數

xhr.abort()

  xhr.setRequestHeader():設置發送的請求頭:

xhr.setRequestHeader("Content-Type","application/json; charset=utf-8")

  第一個參數表示要設置的header,第二個參數表示要設置的header的值。xhr.setRequestHeader()必須在xhr.open()和xhr.send()之間,否則會拋出異常,同時xhr.setRequestHeader()的第一個參數是對大小寫不敏感的只要我們字母寫的對就能夠設置成功,但是出于易讀性我們要設置為正確的格式。

  xhr.overrideMimeType():重寫響應頭的Content-Type:

xhr.overrideMimeType('text/plain; charset=utf-8')

   xhr.overrideMimeType()同樣要設置在xhr.send()之前。

JSON.parse()和JSON.stringify()使用

  JSON.parse()用來將一個對象轉換為字符串,JSON.stringify()用來將一個字符串轉換為對象。在利用ajax進行數據交互的過程中返回的數據多數的時候是一個JSON格式的字符串,如果服務器給我們返回了數據此時我們就需要利用JSON.parse()來解析返回的數據(xhr.responseText即為服務器返回的數據):

xhr.onreadystatechange = function(){
  if(xhr.readyState==4xhr.status==200){
 var data = JSON.parse(xhr.responseText);
  }
}

   在使用post方式發送數據的過程中,如果不是文件上傳一般情況下傳輸的也是一個JSON數據,要想能夠成功的發送到后臺就需要用JSON.stringify()來將JSON對象來轉換為一個字符串,同時Content-Type要設置為application/json:

var sendData = {name:"zt",age:23};
...
xhr.setRequestHeader("Content-Type","application/json; charset=utf-8");
xhr.send(JSON.stringify(sendData));

  另外利用JSON.parse()和JSON.stringify()可以實現一個對象的深拷貝功能:

var sendData = {name:"zt",age:23};
var copyData = JSON.parse(JSON.stringify(sendData));

$.ajax基本使用

   為了方便使用JQ為我們封裝好了一個ajax來方便我們的使用:

$.ajax({
 type:"post",//請求方式
 url:"url",//請求地址
 data:"...",//發送至服務端的數據
 contentType:"...",//設置發送數據的類型如果data是一個json字符串這里要設置為application/json
 success:function(data){...},//請求成功的回調函數data可看做是服務器返回的數據
 error:function(){...}//請求失敗的回調函數
 });

  或者:

$.ajax({
 type:"post",
 url:"url",
 data:"...",
 contentType:"...",
 })
 .done(function(data){...})
 .fail(function(){...});

  回調函數中的data即為服務器返回的數據的一個代理,直接使用即可。

  為了簡化我們的開發JQ提供了一些全局設置函數包括$.ajaxSetup()、$.()ajaxStart()、$().ajaxStop()、$().ajaxComplete()、$().ajaxError()、$().ajaxSuccess()、$().ajaxSend()。

  $.ajaxSetup()用來設置基本的參數例如:

$.ajaxSetup({
 type:"post",
 contentType:"application/json; charset=utf-8"
 });

  我們在使用$.ajax時可以直接這樣設置:

 $.ajax({
 url:"",
 success:function(){...},
 error:function(){...}
 })

  最終等價于:

 $.ajax({
 type:"post",
 contentType:"application/json; charset=utf-8",
 url:"",
 success:function(){...},
 error:function(){...}
 })

  $().ajaxStart()、$().ajaxStop()、$().ajaxComplete()、$().ajaxError()、$().ajaxSuccess()、$().ajaxSend()都是用來設置一些全局回調函數的。例如我們在提交數據時為了防止多次提交我們需要在發送請求時產生一個loading遮罩在數據發送完成后取消遮罩,如果在每一次ajax請求時我們都設置一次就會很麻煩,此時我們就可以用全局回調函數來簡化我們的操作:

  利用全局事件在請求開始時產生一個遮罩在請求完成時取消遮罩:

$(document).ajaxStart(function(){
 loadingMask.show();
 });
 $(document).ajaxComplete(function(){
 loadingMask.hide();
 });

以上所述是小編給大家介紹的Ajax的使用代碼解析,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

您可能感興趣的文章:
  • jQuery使用ajaxSubmit()提交表單示例
  • jquery中ajax使用error調試錯誤的方法
  • 基于jquery的$.ajax async使用
  • jquery.ajax之beforeSend方法使用介紹
  • 使用jquery的ajax需要注意的地方dataType的設置
  • jquery序列化form表單使用ajax提交后處理返回的json數據
  • 跨域請求之jQuery的ajax jsonp的使用解惑
  • Ajax的使用四大步驟
  • 淺析Asp.net MVC 中Ajax的使用
  • AJAX的使用方法詳解

標簽:四川 銅川 遼寧 玉樹 益陽 內江 營口 本溪

巨人網絡通訊聲明:本文標題《Ajax的使用代碼解析》,本文關鍵詞  Ajax,的,使用,代碼,解析,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Ajax的使用代碼解析》相關的同類信息!
  • 本頁收集關于Ajax的使用代碼解析的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    久久久精品tv| 免费在线观看一区| 欧美精品日日鲁夜夜添| 精品一二线国产| 99久久综合色| 日韩专区欧美专区| 日本一区二区视频在线| 欧美色视频一区| 经典三级一区二区| 天天av天天翘天天综合网| 精品福利一二区| 色激情天天射综合网| 青青草原综合久久大伊人精品 | 日韩美女精品在线| 欧美成va人片在线观看| 国模少妇一区二区三区| 亚洲综合久久久| 欧美激情一区二区三区四区| 欧美日韩国产在线播放网站| 色婷婷精品久久二区二区蜜臂av| 久久电影网站中文字幕| 亚洲午夜三级在线| 国产婷婷色一区二区三区在线| 欧美精品v日韩精品v韩国精品v| av日韩在线网站| 九色|91porny| 免费人成在线不卡| 性做久久久久久免费观看| 亚洲国产精品99久久久久久久久| 久久久久久亚洲综合影院红桃| 欧美日韩国产片| 91福利在线播放| www.成人在线| gogo大胆日本视频一区| 亚洲男人天堂一区| 国产精品久久久久永久免费观看 | 视频在线观看一区| 亚洲另类在线一区| 欧美韩国一区二区| 久久久久久亚洲综合| 26uuu欧美| 欧美无砖专区一中文字| 色哦色哦哦色天天综合| 国产成人综合在线播放| 精品一区二区三区的国产在线播放 | 国产色产综合产在线视频| 99在线视频精品| 国产91丝袜在线播放| 天天影视网天天综合色在线播放| 国产精品污网站| 久久婷婷久久一区二区三区| 日韩欧美在线综合网| 欧美一区二区精品久久911| 欧美日韩一级片在线观看| 欧美艳星brazzers| 欧美日韩午夜影院| 欧美一区二区三区四区久久| 欧美日韩精品一区二区三区四区| 色综合天天综合在线视频| 日本韩国欧美在线| 欧美亚洲日本一区| 欧美日韩国产三级| 欧洲av在线精品| 91精品在线免费观看| 日韩一区二区免费电影| 日韩美女视频在线| 久久久亚洲欧洲日产国码αv| 中文字幕在线不卡国产视频| 国产精品第四页| 亚洲乱码精品一二三四区日韩在线| www国产精品av| 91视视频在线观看入口直接观看www | 国产一区二区伦理片| 成人aaaa免费全部观看| 99re66热这里只有精品3直播| 91免费在线看| 欧美日韩在线精品一区二区三区激情| 欧美一级在线免费| 国产亚洲午夜高清国产拍精品| 国产精品国产a级| 亚洲综合清纯丝袜自拍| 一个色妞综合视频在线观看| 婷婷开心激情综合| 国产精品羞羞答答xxdd| 国产精品一级片| 91麻豆高清视频| 91视频免费观看| 欧美一区二区在线免费观看| 在线视频中文字幕一区二区| 日韩午夜小视频| 久久精品免视看| 亚洲一区二区三区国产| 亚洲网友自拍偷拍| 韩国v欧美v日本v亚洲v| 91性感美女视频| 久久综合九色综合欧美就去吻| 日韩一区中文字幕| 午夜久久久久久| 国产成人aaa| 91.com在线观看| 综合av第一页| 日韩va亚洲va欧美va久久| 免费成人在线观看| 99久久精品情趣| 欧美成人综合网站| 亚洲人妖av一区二区| 免费不卡在线视频| 色88888久久久久久影院野外| 日韩欧美一二三区| 亚洲欧美精品午睡沙发| 美女网站色91| 欧美久久一区二区| 国产精品毛片久久久久久久| 久久99久久精品欧美| 色婷婷亚洲一区二区三区| 国产亚洲一区二区在线观看| 午夜成人在线视频| 99久久精品国产毛片| 日韩欧美国产系列| 亚洲大片一区二区三区| av一区二区不卡| 国产精品视频免费| 紧缚捆绑精品一区二区| 日韩视频在线永久播放| 一区二区三区加勒比av| 色狠狠色狠狠综合| 中文字幕欧美日韩一区| 国产一区二区三区香蕉| 91精品欧美福利在线观看| 亚洲一线二线三线视频| caoporm超碰国产精品| 国产精品毛片大码女人| 久久精品国产99| 日韩女优电影在线观看| 午夜欧美在线一二页| 欧美美女直播网站| 亚洲最快最全在线视频| 在线一区二区三区四区| 中文字幕一区二区三区四区| 成人18视频日本| 国产视频亚洲色图| 国产a区久久久| 久久久久9999亚洲精品| 成人激情开心网| 国产欧美综合色| 91女人视频在线观看| 国产精品免费aⅴ片在线观看| 成人激情图片网| 中文字幕一区二区三区av| 91免费看`日韩一区二区| 亚洲精品在线网站| 国产成a人亚洲精品| 7777精品伊人久久久大香线蕉的| 天天av天天翘天天综合网色鬼国产| 欧美日韩成人在线一区| 肉色丝袜一区二区| 欧美一级精品大片| 美腿丝袜一区二区三区| 欧美国产国产综合| 99精品视频在线观看| 亚洲成人动漫在线免费观看| 欧美精品电影在线播放| 免费av成人在线| 精品电影一区二区| 成人一二三区视频| 亚洲日本青草视频在线怡红院| 91国在线观看| 伊人性伊人情综合网| 欧美午夜片在线看| 精品一区二区三区欧美| 久久精品在线免费观看| 色哟哟一区二区三区| 亚洲午夜影视影院在线观看| 欧美v国产在线一区二区三区| 国产v综合v亚洲欧| 亚洲777理论| 欧美精品一区二区在线观看| 成人国产精品免费观看动漫| 亚洲国产精品久久人人爱蜜臀| 在线播放日韩导航| 成人av午夜电影| 一区二区三区欧美日| 精品久久久久久久久久久久久久久 | 国产欧美日韩卡一| 色婷婷综合在线| 久久99精品久久久久久国产越南| 国产蜜臀av在线一区二区三区| 欧美日韩在线电影| 男男视频亚洲欧美| 亚洲资源在线观看| 国产日韩欧美a| 欧美日韩在线直播| 99亚偷拍自图区亚洲| 日本视频在线一区| 亚洲激情av在线| 精品国产一区二区亚洲人成毛片| 欧美在线色视频| 国产乱码精品1区2区3区| 青青草成人在线观看| 久久久一区二区三区捆绑**|