欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js原生Ajax的封裝和原理詳解

 更新時(shí)間:2017年03月11日 10:22:07   作者:sjpqy  
這篇文章主要為大家詳細(xì)介紹了js原生Ajax的封裝和原理,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

原理及概念

AJAX即“Asynchronous Javascript And XML”(異步JavaScript和XML),是一種用于創(chuàng)建快速動(dòng)態(tài)網(wǎng)頁(yè)的技術(shù)。

動(dòng)態(tài)網(wǎng)頁(yè):是指可以通過(guò)服務(wù)器語(yǔ)言結(jié)合數(shù)據(jù)庫(kù)隨時(shí)修改數(shù)據(jù)的網(wǎng)頁(yè)。

靜態(tài)網(wǎng)頁(yè),隨著html代碼的生成,頁(yè)面的內(nèi)容和顯示效果就基本上不會(huì)發(fā)生變化了——除非你修改頁(yè)面代碼。

AJAX = 異步 JavaScript和XML(標(biāo)準(zhǔn)通用標(biāo)記語(yǔ)言的子集)。

AJAX 是與服務(wù)器交換數(shù)據(jù)并更新部分網(wǎng)頁(yè)的藝術(shù),在不重新加載整個(gè)頁(yè)面的情況下。

Ajax的優(yōu)勢(shì)

AJAX 在瀏覽器與 Web 服務(wù)器之間使用異步數(shù)據(jù)傳輸(HTTP 請(qǐng)求),這樣就可使網(wǎng)頁(yè)從服務(wù)器請(qǐng)求少量的信息,而不是整個(gè)頁(yè)面。

AJAX 可使因特網(wǎng)應(yīng)用程序更小、更快,更友好。

AJAX 是一種獨(dú)立于 Web 服務(wù)器軟件的瀏覽器技術(shù)。

AJAX 基于下列 Web 標(biāo)準(zhǔn):

JavaScriptXMLHTMLCSS在 AJAX 中使用的 Web 標(biāo)準(zhǔn)已被良好定義,并被所有的主流瀏覽器支持。AJAX 應(yīng)用程序獨(dú)立于瀏覽器和平臺(tái)。

Web 應(yīng)用程序較桌面應(yīng)用程序有諸多優(yōu)勢(shì);它們能夠涉及廣大的用戶(hù),它們更易安裝及維護(hù),也更易開(kāi)發(fā)。

不過(guò),因特網(wǎng)應(yīng)用程序并不像傳統(tǒng)的桌面應(yīng)用程序那樣完善且友好。

通過(guò) AJAX,因特網(wǎng)應(yīng)用程序可以變得更完善,更友好。

Ajax的異步

異步:是相對(duì)于同步而言的,我們學(xué)過(guò)的定時(shí)器也是異步的一種,也就是其他程序不需要等待定時(shí)器的代碼全部執(zhí)行完畢以后才能執(zhí)行代碼。因?yàn)槎〞r(shí)器有可能是無(wú)限循環(huán)執(zhí)行代碼的,如果等待定時(shí)器執(zhí)行完畢那么其他的代碼將永遠(yuǎn)無(wú)法運(yùn)行。所以異步編程就是相對(duì)于其他代碼是獨(dú)立完成的。也就是上面所說(shuō)的ajax是獨(dú)立于瀏覽器平臺(tái)的。

Tip:事件也是異步執(zhí)行的,事件是發(fā)生某件事情后才會(huì)執(zhí)行代碼的。
同步:我們之前所寫(xiě)的代碼除了定時(shí)器和事件大部分都是同步執(zhí)行的。也就是同一個(gè)代碼塊中都是從上到下執(zhí)行的。

Ajax的工作原理

Ajax 核心對(duì)象XMLHttpRequest
var _hr=new window.XMLHttpRequest();
通過(guò)該實(shí)例化的對(duì)象向服務(wù)器
發(fā)出請(qǐng)求,等待服務(wù)器響應(yīng)
服務(wù)器響應(yīng)完成后客戶(hù)端再處理
服務(wù)器端響應(yīng)的數(shù)據(jù)。
Ajax請(qǐng)求服務(wù)器的過(guò)程中有5個(gè)狀態(tài)
0:表示請(qǐng)求服務(wù)器之前
1:表示打開(kāi)遠(yuǎn)程服務(wù)器鏈接對(duì)應(yīng)open方法
2:表示向服務(wù)器發(fā)送數(shù)據(jù)對(duì)應(yīng)send方法
3:表示服務(wù)器響應(yīng)過(guò)程中并未結(jié)束
4:表示服務(wù)器響應(yīng)完成

/**
 * 創(chuàng)建XMLHttpRequest對(duì)象
 * @param _method 請(qǐng)求方式: post||get
 * @param _url 遠(yuǎn)程服務(wù)器地址
 * @param _async 是否異步
 * @param _parameter 向服務(wù)器發(fā)送數(shù)據(jù)
 * @param _callBack 回調(diào)函數(shù)
 */
function parameterDeal(_parameter){
  var _sender="";
  if(_parameter instanceof Object){
    for(var k in _parameter){
      _sender+=k+"="+_parameter[k]+"&";
    }
    return _sender.replace(/\&$/g,"");
  }else{
    return _parameter;
  }
}
function createXMLHttpRequest(){
  try{
    return new window.XMLHttpRequest();
  }catch(e){
    try{
      return new ActiveXObject("MSXML2.XMLHTTP.6.0");
    }catch(e){
      try{
        return new ActiveXObject("MSXML2.XMLHTTP.3.0");
      }catch(e){
        try{
          return new ActiveXObject("MSXML2.XMLHTTP");
        }catch(e){
          try{
            return new ActiveXObject("Microsoft.XMLHTTP");
          }catch(e){
            throw new Error("該瀏覽器版本太低,已經(jīng)被大部分市場(chǎng)淘汰,請(qǐng)升級(jí)!!!");
            return;
          }
        }
      }
    }
  }
}
function ajaxRequest(_method,_url,_async,_parameter,_callBack){
  var _ajax=createXMLHttpRequest();
  if(_ajax){
    _ajax.onreadystatechange=function(){
      if(_ajax.readyState==4 && _ajax.status==200){
        _callBack(_ajax.responseText);
      }
    }
    _ajax.open(_method,_url,_async);
    _ajax.setRequestHeader("content-type","application/x-www-form-urlencoded;charset=utf-8");
    _ajax.send(parameterDeal(_parameter));
  }
}

這是封裝好了的原生Ajax,在使用的過(guò)程中,只需要新建一個(gè)js文件,將這段代碼放進(jìn)去,什么都不要改,在HTML頁(yè)面引入之后,調(diào)用 ajaxRequest()函數(shù),傳入你想要的參數(shù),就可以正常使用了。

此方法純屬個(gè)人封裝,有更精簡(jiǎn)方法的朋友歡迎與我分享!

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 一文搞懂JavaScript中最難理解概念之一的閉包

    一文搞懂JavaScript中最難理解概念之一的閉包

    閉包常常被譽(yù)為JavaScript中最難理解的概念之一,這篇文章就來(lái)帶大家深入了解一下JavaScript中閉包的概念、實(shí)現(xiàn)與應(yīng)用,需要的可以參考一下
    2023-04-04
  • createObjectURL方法實(shí)現(xiàn)本地圖片預(yù)覽

    createObjectURL方法實(shí)現(xiàn)本地圖片預(yù)覽

    這篇文章主要為大家詳細(xì)介紹了createObjectURL方法實(shí)現(xiàn)本地圖片預(yù)覽,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-09-09
  • 判斷可拖動(dòng)div是否重合 重合多少

    判斷可拖動(dòng)div是否重合 重合多少

    效率較低 該如何優(yōu)化了
    2010-08-08
  • bootstrap weebox 支持ajax的模態(tài)彈出框

    bootstrap weebox 支持ajax的模態(tài)彈出框

    本篇介紹的bootstrap weebox(支持ajax的模態(tài)彈出框),歷經(jīng)多次修改,目前版本已經(jīng)穩(wěn)定,整合了bootstrap的響應(yīng)式,界面簡(jiǎn)單,功能卻無(wú)比豐富,支持ajax、圖片預(yù)覽等等
    2017-02-02
  • 微信小程序?qū)崙?zhàn)教程之WXS語(yǔ)法詳解

    微信小程序?qū)崙?zhàn)教程之WXS語(yǔ)法詳解

    WXS是小程序的一套腳本語(yǔ)言,結(jié)合 WXML,wxs類(lèi)似js和js又不一樣,好多js語(yǔ)法能在js使用不能在wxs使用可以構(gòu)建出頁(yè)面的結(jié)構(gòu),這篇文章主要給大家介紹了關(guān)于微信小程序?qū)崙?zhàn)教程之WXS語(yǔ)法詳解的相關(guān)資料,需要的朋友可以參考下
    2024-09-09
  • JavaScript檢查子字符串是否在字符串中的方法

    JavaScript檢查子字符串是否在字符串中的方法

    這篇文章主要介紹了JavaScript檢查子字符串是否在字符串中的方法,涉及JavaScript查詢(xún)、正則匹配等操作技巧,需要的朋友可以參考下
    2016-02-02
  • js移動(dòng)端事件基礎(chǔ)及常用事件庫(kù)詳解

    js移動(dòng)端事件基礎(chǔ)及常用事件庫(kù)詳解

    這篇文章主要為大家詳細(xì)介紹了js移動(dòng)端事件基礎(chǔ)及常用事件庫(kù),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • JavaScript實(shí)現(xiàn)窗口抖動(dòng)效果

    JavaScript實(shí)現(xiàn)窗口抖動(dòng)效果

    抖動(dòng)效果在各大網(wǎng)頁(yè)上都常遇到,這篇文章主要介紹了JavaScript實(shí)現(xiàn)窗口抖動(dòng)效果的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-10-10
  • js+css實(shí)現(xiàn)有立體感的按鈕式文字豎排菜單效果

    js+css實(shí)現(xiàn)有立體感的按鈕式文字豎排菜單效果

    這篇文章主要介紹了js+css實(shí)現(xiàn)有立體感的按鈕式文字豎排菜單效果,通過(guò)javascript動(dòng)態(tài)調(diào)用頁(yè)面元素樣式實(shí)現(xiàn)豎排菜單的功能,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-09-09
  • 一個(gè)簡(jiǎn)單的JS鼠標(biāo)懸停特效具體方法

    一個(gè)簡(jiǎn)單的JS鼠標(biāo)懸停特效具體方法

    這個(gè)特效最終實(shí)現(xiàn)效果就是當(dāng)鼠標(biāo)移動(dòng)到鏈接上,文字會(huì)橫向移動(dòng)一定距離,貌似總有人喜歡這些花花草草。添加此效果方法很簡(jiǎn)單。
    2013-06-06

最新評(píng)論