<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        Ajax的使用代碼解析

        來源:懂視網 責編:小采 時間:2020-11-27 22:51:49
        文檔

        Ajax的使用代碼解析

        Ajax的使用代碼解析:Ajax 簡介 Ajax被認為是(Asynchronous(異步) JavaScript And Xml的縮寫)。現在,允許瀏覽器與服務器通信而無須刷新當前頁面的技術都被叫做Ajax. 同步是指:發送方發出數據后,等接收方發回響應以后才發下一個數據包的通訊方式。 異步是指:發送方發出數據
        推薦度:
        導讀Ajax的使用代碼解析:Ajax 簡介 Ajax被認為是(Asynchronous(異步) JavaScript And Xml的縮寫)。現在,允許瀏覽器與服務器通信而無須刷新當前頁面的技術都被叫做Ajax. 同步是指:發送方發出數據后,等接收方發回響應以后才發下一個數據包的通訊方式。 異步是指:發送方發出數據

        Ajax 簡介

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

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

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

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

      1. Flash 框架
      2. Frameset:如果使用一組框架構造了一個網頁,可以只更新其中一個框架,而不必驚動整個頁面
      3. XMLHttpRequest:該對象是對 JavaScript 的一個擴展,可使網頁與服務器進行通信。是創建 Ajax 應用的最佳選擇。實際上通常把 Ajax 當成XMLHttpRequest(XHR) 對象的代名詞
      4. 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=zt&age=23",true);
        xhr.send(null);
        xhr.onreadystatechange = function(){
          if(xhr.readyState==4&&xhr.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==4&&xhr.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==4&&xhr.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的使用代碼解析,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        Ajax的使用代碼解析

        Ajax的使用代碼解析:Ajax 簡介 Ajax被認為是(Asynchronous(異步) JavaScript And Xml的縮寫)。現在,允許瀏覽器與服務器通信而無須刷新當前頁面的技術都被叫做Ajax. 同步是指:發送方發出數據后,等接收方發回響應以后才發下一個數據包的通訊方式。 異步是指:發送方發出數據
        推薦度:
        標簽: 使用 講解 代碼
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 国产久爱免费精品视频| 亚洲欧美日韩综合俺去了| 无遮挡a级毛片免费看| 国内大片在线免费看| 亚洲日本香蕉视频观看视频| 无码人妻一区二区三区免费n鬼沢| 狠狠综合久久综合88亚洲| 中文字幕不卡免费视频| 亚洲国产综合无码一区| 免费无码黄网站在线看| 久久久久亚洲AV片无码| 中文字幕无码一区二区免费| 亚洲Av永久无码精品三区在线 | 国产做床爱无遮挡免费视频| 亚洲中文字幕久久精品无码A| 日韩精品免费电影| 高清免费久久午夜精品| 亚洲伊人色欲综合网| 玖玖在线免费视频| 亚洲人成网站日本片| 在线观看人成视频免费| 日本特黄特色AAA大片免费| 久久久久噜噜噜亚洲熟女综合| 99精品免费视频| 亚洲美女免费视频| 日日AV拍夜夜添久久免费| 一级看片免费视频| 亚洲AV成人精品网站在线播放| 99视频全部免费精品全部四虎| 理论亚洲区美一区二区三区| 国产精品亚洲产品一区二区三区| 国产精品99精品久久免费| 久久精品亚洲AV久久久无码 | 一本色道久久综合亚洲精品| 日韩免费电影网址| 亚洲AV一二三区成人影片| 全部免费国产潢色一级| 久久国产乱子精品免费女| 亚洲精品无码成人片久久不卡 | 日韩成人免费视频| 亚洲熟妇AV一区二区三区宅男|