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

主頁 > 知識(shí)庫(kù) > Ajax的使用代碼解析

Ajax的使用代碼解析

熱門標(biāo)簽:立陶宛地圖標(biāo)注 電銷機(jī)器人 長(zhǎng)春 地圖標(biāo)注推銷坑人 大眾點(diǎn)評(píng)400電話怎么申請(qǐng) 怎樣在地圖標(biāo)注文字 河間市地圖標(biāo)注app 中國(guó)地圖標(biāo)注不明確情況介紹表 上海企業(yè)外呼系統(tǒng)價(jià)錢 東平縣地圖標(biāo)注app

Ajax 簡(jiǎn)介

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

同步是指:發(fā)送方發(fā)出數(shù)據(jù)后,等接收方發(fā)回響應(yīng)以后才發(fā)下一個(gè)數(shù)據(jù)包的通訊方式。 

異步是指:發(fā)送方發(fā)出數(shù)據(jù)后,不等接收方發(fā)回響應(yīng),接著發(fā)送下個(gè)數(shù)據(jù)包的通訊方式 。

通常不用刷新網(wǎng)頁而與服務(wù)器通訊的方法:

  • Flash 框架
  • Frameset:如果使用一組框架構(gòu)造了一個(gè)網(wǎng)頁,可以只更新其中一個(gè)框架,而不必驚動(dòng)整個(gè)頁面
  • XMLHttpRequest:該對(duì)象是對(duì) JavaScript 的一個(gè)擴(kuò)展,可使網(wǎng)頁與服務(wù)器進(jìn)行通信。是創(chuàng)建 Ajax 應(yīng)用的最佳選擇。實(shí)際上通常把 Ajax 當(dāng)成XMLHttpRequest(XHR) 對(duì)象的代名詞

ajax基本使用

  ajax在我們的開發(fā)中是必須使用的一個(gè)技術(shù),ajax即異步的javascript和xml但是現(xiàn)在我們通常使用json來完成數(shù)據(jù)的交互,ajax職責(zé)很單一就是數(shù)據(jù)的交互,發(fā)送數(shù)據(jù)接收數(shù)據(jù)是它的核心功能也是唯一的功能。

  ajax的實(shí)現(xiàn)依賴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的職責(zé)就是發(fā)送數(shù)據(jù)和接收數(shù)據(jù)我們基本使用流程為:

  1.獲取一個(gè)XMLHttpRequest對(duì)象

  2.發(fā)送數(shù)據(jù)

  3.接收處理服務(wù)器返回的數(shù)據(jù)

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

  此時(shí)我們已經(jīng)得到了xhr對(duì)象接下來就是發(fā)送數(shù)據(jù),通過xhr.open()方法來執(zhí)行發(fā)送數(shù)據(jù)的方式,xhr.open()可以接收5個(gè)參數(shù),我們經(jīng)常使用的是前三個(gè):

xhr.open(arg1,arg2,arg3)

  arg1表示請(qǐng)求數(shù)據(jù)的方式一般為get或者post

  arg2表示請(qǐng)求的服務(wù)器地址

  arg3表示本次請(qǐng)求是同步還是異步,ajax的突出特點(diǎn)就是異步所以我們一般都是使用異步的方式第三個(gè)參數(shù)設(shè)置為true(true表示進(jìn)行異步請(qǐng)求false表示進(jìn)行同步請(qǐng)求)

  xhr.open()方法只是準(zhǔn)備一個(gè)請(qǐng)求,在調(diào)用open之后并不會(huì)和服務(wù)器進(jìn)行通訊,而是在調(diào)用send()函數(shù)之后才會(huì)和服務(wù)器開始通訊,send()函數(shù)的參數(shù)將作為請(qǐng)求體發(fā)送到服務(wù)端。如果我們?cè)趏pen()函數(shù)中指定請(qǐng)求的方式為get通常我們將send()設(shè)置為xhr.send(null),如果我們希望通過請(qǐng)求體發(fā)送數(shù)據(jù)則要將open()函數(shù)的請(qǐng)求方式設(shè)置為post同時(shí)將我們需要發(fā)送的數(shù)據(jù)作為send()函數(shù)的參數(shù):xhr.send(param),在調(diào)用send()函數(shù)之后,和服務(wù)器的通訊就開始了。

  對(duì)xhr的所有的設(shè)置都應(yīng)該在send()函數(shù)之前設(shè)置好:

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

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

  在send()之后可以通過xhr.readyState和xhr.status的來監(jiān)測(cè)本次請(qǐng)求的狀態(tài),如果滿足xhr.readyState==4xhr.status==200則本次請(qǐng)求成功:

在請(qǐng)求成功時(shí)我們可以通過xhr.responseText來獲取服務(wù)器返回的數(shù)據(jù),需要注意xhr.responseText是一個(gè)字符串。

ajax常用API

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

  xhr.abort():終止一個(gè)請(qǐng)求,直接調(diào)用即可不需要設(shè)置參數(shù)

xhr.abort()

  xhr.setRequestHeader():設(shè)置發(fā)送的請(qǐng)求頭:

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

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

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

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

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

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

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

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

   在使用post方式發(fā)送數(shù)據(jù)的過程中,如果不是文件上傳一般情況下傳輸?shù)囊彩且粋€(gè)JSON數(shù)據(jù),要想能夠成功的發(fā)送到后臺(tái)就需要用JSON.stringify()來將JSON對(duì)象來轉(zhuǎn)換為一個(gè)字符串,同時(shí)Content-Type要設(shè)置為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()可以實(shí)現(xiàn)一個(gè)對(duì)象的深拷貝功能:

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

$.ajax基本使用

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

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

  或者:

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

  回調(diào)函數(shù)中的data即為服務(wù)器返回的數(shù)據(jù)的一個(gè)代理,直接使用即可。

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

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

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

  我們?cè)谑褂?.ajax時(shí)可以直接這樣設(shè)置:

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

  最終等價(jià)于:

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

  $().ajaxStart()、$().ajaxStop()、$().ajaxComplete()、$().ajaxError()、$().ajaxSuccess()、$().ajaxSend()都是用來設(shè)置一些全局回調(diào)函數(shù)的。例如我們?cè)谔峤粩?shù)據(jù)時(shí)為了防止多次提交我們需要在發(fā)送請(qǐng)求時(shí)產(chǎn)生一個(gè)loading遮罩在數(shù)據(jù)發(fā)送完成后取消遮罩,如果在每一次ajax請(qǐng)求時(shí)我們都設(shè)置一次就會(huì)很麻煩,此時(shí)我們就可以用全局回調(diào)函數(shù)來簡(jiǎn)化我們的操作:

  利用全局事件在請(qǐng)求開始時(shí)產(chǎn)生一個(gè)遮罩在請(qǐng)求完成時(shí)取消遮罩:

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

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

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

標(biāo)簽:四川 銅川 遼寧 玉樹 益陽 內(nèi)江 營(yíng)口 本溪

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Ajax的使用代碼解析》,本文關(guān)鍵詞  Ajax,的,使用,代碼,解析,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Ajax的使用代碼解析》相關(guān)的同類信息!
  • 本頁收集關(guān)于Ajax的使用代碼解析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲第一激情av| 久久久久久久综合色一本| 亚洲美女在线国产| 欧美精品777| 欧美国产一区在线| 欧美狂野另类xxxxoooo| 99国产精品久久久久久久久久 | 欧美乱妇一区二区三区不卡视频| 国产成人精品一区二区三区四区| 国产成人8x视频一区二区| 国产99久久久国产精品潘金| 国产乱对白刺激视频不卡| 国模无码大尺度一区二区三区| 久久99精品国产麻豆婷婷| 国内精品国产成人| voyeur盗摄精品| 欧美中文字幕亚洲一区二区va在线| 色先锋资源久久综合| 日韩欧美一级片| 中文字幕一区二区三区av | 亚洲午夜激情av| 日本视频中文字幕一区二区三区| 美脚の诱脚舐め脚责91 | 精品一区二区三区久久久| 97久久超碰国产精品电影| 7777精品伊人久久久大香线蕉完整版 | 日韩精品成人一区二区三区| 国内一区二区视频| 欧美曰成人黄网| 国产精品久久久久久久蜜臀| 亚洲成a人v欧美综合天堂下载| 国产真实乱对白精彩久久| 麻豆成人91精品二区三区| 日韩精品一区二区在线| 久久综合丝袜日本网| 亚洲精品美腿丝袜| 黄页网站大全一区二区| 日韩视频一区在线观看| 亚洲精品乱码久久久久| aaa欧美色吧激情视频| 久久亚区不卡日本| 国产原创一区二区| xnxx国产精品| 国产久卡久卡久卡久卡视频精品| 欧美一区二区视频免费观看| 最好看的中文字幕久久| 色素色在线综合| 一区二区国产视频| 欧美色视频在线观看| 亚洲一区二区三区自拍| 日韩欧美一区在线观看| 亚洲国产中文字幕| 日韩欧美在线123| 国产a区久久久| 亚洲精品美腿丝袜| 日韩午夜电影av| 国产精品小仙女| 亚洲精品免费看| 欧美电视剧在线观看完整版| 粉嫩绯色av一区二区在线观看| 国产精品热久久久久夜色精品三区| proumb性欧美在线观看| 亚洲国产成人va在线观看天堂| 欧美丰满一区二区免费视频| 国产乱子伦一区二区三区国色天香| 国产日韩欧美精品在线| 色综合天天综合狠狠| 久久国产精品无码网站| 日韩一卡二卡三卡四卡| 91一区在线观看| 韩国女主播成人在线| 亚洲综合激情网| 欧美激情一区三区| 在线播放欧美女士性生活| av不卡免费在线观看| 国产真实乱偷精品视频免| 青青草国产精品亚洲专区无| 亚洲成人激情自拍| 国产精品综合在线视频| 天天影视涩香欲综合网| 亚洲素人一区二区| 国产精品美女久久久久久久久| 日韩精品一区二区三区视频播放| 欧美日本高清视频在线观看| 色综合色综合色综合色综合色综合 | 国内久久精品视频| 国产麻豆精品theporn| 国产在线看一区| 免费看欧美美女黄的网站| 天堂影院一区二区| 亚洲bdsm女犯bdsm网站| 午夜精品福利视频网站| 日本特黄久久久高潮| 国产精品三级视频| 中文字幕在线一区二区三区| 国产精品欧美一级免费| 亚洲欧洲日韩在线| 日本一区二区久久| 亚洲图片欧美色图| 久久se精品一区二区| 国产精品亚洲一区二区三区妖精 | 日本vs亚洲vs韩国一区三区二区| 亚洲精品在线网站| 国产三级一区二区三区| 国产精品久久777777| 日本免费在线视频不卡一不卡二| 激情综合五月天| 在线观看精品一区| 精品国产一区久久| 亚洲欧洲无码一区二区三区| 日韩电影免费在线| 成人午夜视频免费看| 日韩视频一区二区三区在线播放| 久久久91精品国产一区二区精品 | 久久久欧美精品sm网站| 国产精品高潮久久久久无| 亚洲成人777| 一本色道久久综合精品竹菊| 51午夜精品国产| 亚洲午夜精品在线| 色婷婷久久综合| 1000精品久久久久久久久| 极品少妇xxxx偷拍精品少妇| 狠狠久久亚洲欧美| 日韩欧美国产精品| 精品无人区卡一卡二卡三乱码免费卡| 在线观看91精品国产入口| 国产亲近乱来精品视频| 国产精品一区二区你懂的| 欧美精品一区二区三区一线天视频 | 日韩视频免费直播| 麻豆精品久久精品色综合| 亚洲精品一区二区三区蜜桃下载| 极品美女销魂一区二区三区| 欧美视频日韩视频在线观看| 亚洲精品一二三四区| 91亚洲国产成人精品一区二三| 日韩理论片一区二区| 欧美在线999| 国产成人av一区二区| 亚洲人成小说网站色在线| 欧美色综合久久| 精品一区二区精品| 综合久久久久综合| 欧美年轻男男videosbes| 蜜桃在线一区二区三区| 亚洲高清免费视频| 国产精品情趣视频| 日韩精品中文字幕一区| 日本韩国一区二区三区视频| 亚洲成人激情综合网| 国产女人水真多18毛片18精品视频| 成人av在线资源网站| 国产精品一区二区久激情瑜伽| 欧美日韩国产精品自在自线| jlzzjlzz欧美大全| 国产精品中文字幕一区二区三区| 樱桃视频在线观看一区| 国产精品国产三级国产aⅴ原创| 久久综合九色综合97_久久久 | 国产精品一品视频| 偷窥少妇高潮呻吟av久久免费| 国产精品免费丝袜| 久久蜜桃av一区精品变态类天堂| 欧美性猛交xxxxxxxx| 亚洲人成小说网站色在线 | 成人深夜在线观看| 国产乱码一区二区三区| 日韩va亚洲va欧美va久久| 亚洲私人影院在线观看| 欧美国产综合一区二区| 亚洲国产精品国自产拍av| 日韩欧美高清在线| 欧美日韩精品是欧美日韩精品| 成人黄色777网| 色88888久久久久久影院按摩| 国产91露脸合集magnet| 国产精品自在欧美一区| 国产成人精品免费| av高清久久久| 91蜜桃婷婷狠狠久久综合9色| 一本在线高清不卡dvd| 欧美日本在线播放| www国产精品av| 亚洲激情一二三区| 免费在线成人网| 国产成人午夜视频| 在线亚洲高清视频| 欧美精品一区二区三区四区| 欧美韩国一区二区| 亚洲高清不卡在线| 国产盗摄视频一区二区三区| 欧美亚洲综合一区| 中文字幕日韩av资源站| 三级在线观看一区二区| 99久久精品国产一区二区三区| 精品国产乱码久久久久久牛牛| 一区二区高清在线| 成人深夜福利app| 久久久无码精品亚洲日韩按摩|