婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 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的使用代碼解析的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美一区二区私人影院日本| 91精品麻豆日日躁夜夜躁| 一区二区国产视频| 久久精品一二三| 91精品国产麻豆国产自产在线 | 成人免费视频视频| 蜜桃视频在线观看一区| 国产精品久久久久影视| 久久免费看少妇高潮| 久久亚洲精品小早川怜子| 欧美一区二区精品| 亚洲欧美成人一区二区三区| 亚洲欧洲日产国码二区| 亚洲天堂2014| 亚洲一区在线观看免费| 亚洲伦在线观看| 午夜精品爽啪视频| 日本va欧美va瓶| 久久综合色8888| 日本免费在线视频不卡一不卡二 | 在线不卡中文字幕| 91精品国产91热久久久做人人| 欧美国产精品久久| 1区2区3区欧美| 成人黄色电影在线 | 久久精品夜夜夜夜久久| 另类的小说在线视频另类成人小视频在线 | 国产一二精品视频| 高清日韩电视剧大全免费| 91丨porny丨首页| 欧美日韩精品系列| 精品国产自在久精品国产| 国产精品蜜臀av| 亚洲不卡在线观看| 国产不卡视频在线观看| 亚洲精品一区二区精华| 精品在线一区二区三区| 色婷婷综合在线| 在线成人av网站| 老司机精品视频导航| 精品精品欲导航| 亚洲人快播电影网| 91久久国产综合久久| 精品国产乱码久久久久久老虎 | 欧美性欧美巨大黑白大战| 91.麻豆视频| 蜜乳av一区二区| 久久久久久97三级| av中文字幕不卡| 欧美v日韩v国产v| 国产成人av在线影院| 3751色影院一区二区三区| 日韩在线观看一区二区| 色偷偷久久人人79超碰人人澡| 亚洲精品视频在线看| 56国语精品自产拍在线观看| 精品综合久久久久久8888| 国产精品毛片高清在线完整版| 99精品桃花视频在线观看| 久久综合久久综合久久综合| 粗大黑人巨茎大战欧美成人| 一区二区三区成人| 日韩片之四级片| 亚洲成人你懂的| 精品久久久久一区| 97se亚洲国产综合在线| 青草av.久久免费一区| 日本一区二区免费在线| 亚洲一级不卡视频| 精品国产乱码久久久久久免费| jiyouzz国产精品久久| 亚洲成人av在线电影| 国产欧美日韩在线视频| 欧美精品高清视频| 成人精品一区二区三区中文字幕 | 日韩精品在线看片z| 亚洲一区二区视频在线| 久久中文娱乐网| 欧美色区777第一页| 亚洲综合久久久久| 久久久天堂av| 欧美老女人第四色| 色综合色狠狠综合色| 狠狠色狠狠色综合系列| 国产亚洲制服色| 欧美精品1区2区3区| 在线视频一区二区三区| 亚洲欧美视频一区| 久久青草国产手机看片福利盒子| 欧美日韩中文字幕一区| 不卡电影免费在线播放一区| 精品一区二区久久久| 日日摸夜夜添夜夜添国产精品| 亚洲男同1069视频| 国产人成一区二区三区影院| 欧美大黄免费观看| 91精品一区二区三区在线观看| 91成人免费在线视频| 91蜜桃网址入口| av中文一区二区三区| www.亚洲免费av| 成人av在线资源网| 国产精品亚洲人在线观看| 亚洲图片欧美激情| 中文字幕在线免费不卡| 欧美国产在线观看| 国产日产亚洲精品系列| 国产亚洲一区二区三区四区| 欧美精品一区二区三区一线天视频 | 日本免费在线视频不卡一不卡二| 亚洲国产精品久久不卡毛片| 欧美日本一道本| 欧美色爱综合网| 欧美三级视频在线| 欧美日韩一区二区在线观看| 欧美日韩精品一区视频| 欧美日韩国产a| 3d动漫精品啪啪一区二区竹菊| 欧美精品乱码久久久久久| 欧美男人的天堂一二区| 91精品国产一区二区三区| 91麻豆精品91久久久久同性| 精品久久久久久久久久久院品网 | 欧美日韩精品二区第二页| 欧美猛男gaygay网站| 欧美一级精品在线| 精品av久久707| 国产精品人人做人人爽人人添| 亚洲欧美综合色| 亚洲精品一二三| 日韩不卡一区二区| 国产精品系列在线播放| www.日本不卡| 欧美日韩你懂得| 久久综合网色—综合色88| 国产午夜久久久久| 一区二区三区日韩精品| 奇米影视7777精品一区二区| 国产一区 二区| 91亚洲精华国产精华精华液| 欧美日韩亚洲高清一区二区| www精品美女久久久tv| 亚洲色图欧洲色图| 丝瓜av网站精品一区二区| 国产精品99久久不卡二区| 色94色欧美sute亚洲线路二| 日韩精品最新网址| 中文字幕视频一区| 老司机午夜精品| 91蜜桃视频在线| 久久久久成人黄色影片| 亚洲一级电影视频| 国产成人精品亚洲日本在线桃色| 欧美性一级生活| 国产欧美日韩另类视频免费观看| 亚洲已满18点击进入久久| 国产精品一二二区| 91精品国产综合久久久久| 国产精品国产三级国产aⅴ入口 | 精品国产一区二区三区久久影院| 欧美激情在线看| 性做久久久久久免费观看| 粉嫩蜜臀av国产精品网站| 这里是久久伊人| 亚洲三级电影全部在线观看高清| 久久国产精品一区二区| 在线观看国产一区二区| 国产女人18毛片水真多成人如厕 | 欧美私模裸体表演在线观看| 久久免费电影网| 美女网站一区二区| 91传媒视频在线播放| 中文字幕一区二| 国产激情一区二区三区桃花岛亚洲| 欧美精品在线一区二区| 亚洲精品一二三| 99久久精品国产麻豆演员表| 久久久久免费观看| 久久电影网站中文字幕| 69久久99精品久久久久婷婷| 亚洲综合一二区| 色婷婷久久久综合中文字幕| 国产情人综合久久777777| 久久99精品国产| 日韩精品一区二区三区在线观看| 亚洲成人先锋电影| 欧美日韩你懂的| 视频一区二区国产| 欧美老肥妇做.爰bbww| 亚洲第一福利视频在线| 欧洲国内综合视频| 亚洲一区二区在线免费看| 一本久道中文字幕精品亚洲嫩| 中文字幕第一区综合| av在线不卡免费看| 国产精品久久久久久户外露出| 成人精品亚洲人成在线| 国产精品另类一区| 色婷婷久久99综合精品jk白丝 | 亚洲日本中文字幕区|