原生js實(shí)現(xiàn)Ajax

Ajax的原理:

簡(jiǎn)單來說就是 通過XmlHttpRequest對(duì)象向服務(wù)器發(fā)異步請(qǐng)求乍丈,從服務(wù)器獲得數(shù)據(jù),然后用 javascript 來操作DOM更新頁(yè)面的技術(shù)虹茶。

一般來說疑故,大家可能都會(huì)習(xí)慣用JQuery提供的Ajax方法,但是用原生的js怎么去實(shí)現(xiàn)Ajax方法呢俏讹?

JQuery提供的Ajax方法:

$.ajax({
    url: ,
    type: '',
    dataType: '',
    data: {
          
    },
    success: function(){
         
    },
    error: function(){
          
    }
 })

原生js實(shí)現(xiàn)Ajax方法是這樣的:

var Ajax = {
    get: function(url,callback){
        // XMLHttpRequest對(duì)象用于在后臺(tái)與服務(wù)器交換數(shù)據(jù)
        var xhr=new XMLHttpRequest();
        xhr.open('GET',url,false);
        xhr.onreadystatechange=function(){
            // readyState == 4說明請(qǐng)求已完成
            if(xhr.readyState==4){
                if(xhr.status==200 || xhr.status==304){
                    console.log(xhr.responseText);
                    callback(xhr.responseText);
                }
            }
        }
        xhr.send();
    },

    // data應(yīng)為'a=a1&b=b1'這種字符串格式当宴,在jq里如果data為對(duì)象會(huì)自動(dòng)將對(duì)象轉(zhuǎn)成這種字符串格式
    post: function(url,data,callback){
        var xhr=new XMLHttpRequest();
        xhr.open('POST',url,false);
        // 添加http頭,發(fā)送信息至服務(wù)器時(shí)內(nèi)容編碼類型
        xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
        xhr.onreadystatechange=function(){
            if (xhr.readyState==4){
                if (xhr.status==200 || xhr.status==304){
                    // console.log(xhr.responseText);
                    callback(xhr.responseText);
                }
            }
        }
        xhr.send(data);
    }
}

代碼注釋:

  1. open(method, url, async) 方法需要三個(gè)參數(shù):

method:發(fā)送請(qǐng)求所使用的方法(GET或POST)泽疆;與POST相比户矢,GET更簡(jiǎn)單也更快,并且在大部分情況下都能用殉疼;然而梯浪,在以下情況中,請(qǐng)使用POST請(qǐng)求:

①無法使用緩存文件(更新服務(wù)器上的文件或數(shù)據(jù)庫(kù))
②向服務(wù)器發(fā)送大量數(shù)據(jù)(POST 沒有數(shù)據(jù)量限制)
③發(fā)送包含未知字符的用戶輸入時(shí)瓢娜,POST 比 GET 更穩(wěn)定也更可靠

url:規(guī)定服務(wù)器端腳本的 URL(該文件可以是任何類型的文件挂洛,比如 .txt 和 .xml,或者服務(wù)器腳本文件眠砾,比如 .asp 和 .php (在傳回響應(yīng)之前虏劲,能夠在服務(wù)器上執(zhí)行任務(wù)));

async:規(guī)定應(yīng)當(dāng)對(duì)請(qǐng)求進(jìn)行異步(true)或同步(false)處理褒颈;true是在等待服務(wù)器響應(yīng)時(shí)執(zhí)行其他腳本柒巫,當(dāng)響應(yīng)就緒后對(duì)響應(yīng)進(jìn)行處理;false是等待服務(wù)器響應(yīng)再執(zhí)行谷丸。

  1. send() 方法可將請(qǐng)求送往服務(wù)器堡掏。

  2. onreadystatechange:存有處理服務(wù)器響應(yīng)的函數(shù),每當(dāng) readyState 改變時(shí)刨疼,onreadystatechange 函數(shù)就會(huì)被執(zhí)行布疼。

  3. readyState:存有服務(wù)器響應(yīng)的狀態(tài)信息摊趾。

0: 請(qǐng)求未初始化(代理被創(chuàng)建,但尚未調(diào)用 open() 方法)
1: 服務(wù)器連接已建立(open方法已經(jīng)被調(diào)用)
2: 請(qǐng)求已接收(send方法已經(jīng)被調(diào)用游两,并且頭部和狀態(tài)已經(jīng)可獲得)
3: 請(qǐng)求處理中(下載中砾层,responseText 屬性已經(jīng)包含部分?jǐn)?shù)據(jù))
4: 請(qǐng)求已完成,且響應(yīng)已就緒(下載操作已完成)

  1. responseText:獲得字符串形式的響應(yīng)數(shù)據(jù)贱案。

  2. setRequestHeader():POST傳數(shù)據(jù)時(shí)肛炮,用來添加 HTTP 頭,然后send(data)宝踪,注意data格式侨糟;GET發(fā)送信息時(shí)直接加參數(shù)到url上就可以,比如url?a=a1&b=b1瘩燥。

Ajax的原理:

Ajax 的原理簡(jiǎn)單來說通過 XmlHttpRequest 對(duì)象來向服務(wù)器發(fā)異步請(qǐng)求秕重,從服務(wù)器獲得數(shù)據(jù),然后用javascript來操作DOM而更新頁(yè)面厉膀。這其中最關(guān)鍵的一步就是從服務(wù)器獲得請(qǐng)求數(shù)據(jù)溶耘。

要清楚這個(gè)過程和原理,我們必須對(duì) XMLHttpRequest 有所了解服鹅。XMLHttpRequest 是 ajax 的核心機(jī)制凳兵,它是在 IE5 中首先引入的,是一種支持異步請(qǐng)求的技術(shù)企软。簡(jiǎn)單的說庐扫,也就是 javascript 可以及時(shí)向服務(wù)器提出請(qǐng)求和處理響應(yīng),而不阻塞用戶仗哨,達(dá)到無刷新的效果形庭。

拓展ES6的 Promise 的AJAX GET方法請(qǐng)求數(shù)據(jù):

const getJSON = function(url) {
    const promise = new Promise(function(resolve, reject){
        const handler = function() {
            if (this.readyState !== 4) {
                return;
            }
            if (this.status === 200) {
                resolve(this.response);
            } else {
                reject(new Error(this.statusText));
            }
        };
        const client = new XMLHttpRequest();
        client.open("GET", url);
        client.onreadystatechange = handler;
        client.responseType = "json";
        client.setRequestHeader("Accept", "application/json");
        client.send();

    });
    return promise;
};
getJSON("promise.json").then(function(json) {
    console.log('Data: ', json);
}, function(error) {
    console.error('err', error);
});
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市厌漂,隨后出現(xiàn)的幾起案子碘勉,更是在濱河造成了極大的恐慌,老刑警劉巖桩卵,帶你破解...
    沈念sama閱讀 216,591評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異倍宾,居然都是意外死亡雏节,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門高职,熙熙樓的掌柜王于貴愁眉苦臉地迎上來钩乍,“玉大人,你說我怎么就攤上這事怔锌×却猓” “怎么了变过?”我有些...
    開封第一講書人閱讀 162,823評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)涝涤。 經(jīng)常有香客問我媚狰,道長(zhǎng),這世上最難降的妖魔是什么阔拳? 我笑而不...
    開封第一講書人閱讀 58,204評(píng)論 1 292
  • 正文 為了忘掉前任崭孤,我火速辦了婚禮,結(jié)果婚禮上糊肠,老公的妹妹穿的比我還像新娘辨宠。我一直安慰自己,他們只是感情好货裹,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,228評(píng)論 6 388
  • 文/花漫 我一把揭開白布嗤形。 她就那樣靜靜地躺著,像睡著了一般弧圆。 火紅的嫁衣襯著肌膚如雪赋兵。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,190評(píng)論 1 299
  • 那天墓阀,我揣著相機(jī)與錄音毡惜,去河邊找鬼。 笑死斯撮,一個(gè)胖子當(dāng)著我的面吹牛经伙,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播勿锅,決...
    沈念sama閱讀 40,078評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼帕膜,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了溢十?” 一聲冷哼從身側(cè)響起垮刹,我...
    開封第一講書人閱讀 38,923評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎张弛,沒想到半個(gè)月后荒典,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,334評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡吞鸭,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,550評(píng)論 2 333
  • 正文 我和宋清朗相戀三年寺董,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片刻剥。...
    茶點(diǎn)故事閱讀 39,727評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡遮咖,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出造虏,到底是詐尸還是另有隱情御吞,我是刑警寧澤麦箍,帶...
    沈念sama閱讀 35,428評(píng)論 5 343
  • 正文 年R本政府宣布,位于F島的核電站陶珠,受9級(jí)特大地震影響挟裂,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜背率,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,022評(píng)論 3 326
  • 文/蒙蒙 一话瞧、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧寝姿,春花似錦交排、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至根资,卻和暖如春架专,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背玄帕。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工部脚, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人裤纹。 一個(gè)月前我還...
    沈念sama閱讀 47,734評(píng)論 2 368
  • 正文 我出身青樓委刘,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親鹰椒。 傳聞我的和親對(duì)象是個(gè)殘疾皇子锡移,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,619評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容