使用JavaScript?定義自己的ajax函數(shù)
由于用原生js的方式發(fā)起的網(wǎng)絡(luò)請(qǐng)求,都是以查詢字符串的形式,提交給服務(wù)器的,用戶以對(duì)象的形式提交參數(shù)的話會(huì)比較方便,所以需要把用戶傳遞過來的參數(shù)對(duì)象進(jìn)行處理,定義resolveData的函數(shù),設(shè)置形參接收參數(shù),遍歷里面的對(duì)象,把鍵和值用=的方式進(jìn)行拼接,然后把所得的值添加進(jìn)空的數(shù)組即可;最后用&符號(hào)把數(shù)組的每一項(xiàng)進(jìn)行分割,并返回;定義itheima函數(shù),設(shè)置形參用于接收用戶傳遞過來的配置對(duì)象參數(shù),創(chuàng)建xhr對(duì)象,把傳遞過來的參數(shù)傳遞給處理參數(shù)的函數(shù),把得到的返回值,給一個(gè)變量,由于是不同的請(qǐng)求,所以要進(jìn)行判斷,首先是GET請(qǐng)求,判斷參數(shù)里面的method是否全等于GET,由于傳遞過來的參數(shù)有可能是小寫,所以通過toUpperCase方法轉(zhuǎn)化為大寫,如果條件成立調(diào)用open方法,把對(duì)應(yīng)的值填入即可,調(diào)用send函數(shù);POST也一樣,只是提交數(shù)據(jù)多了參數(shù)和POST請(qǐng)求需要“Content-Type”頭指定請(qǐng)求主題的MIME類型。最后調(diào)用監(jiān)聽事件即可;
function resolveData(data) { var arr = []; for (var k in data) { var str = k + "=" + data[k]; arr.push(str) } return arr.join("&") } function itheima(options) { var xhr = new XMLHttpRequest(); var qs = resolveData(options.data); if (options.method.toUpperCase() === "GET") { xhr.open(options.method, options.url + "?" + qs); xhr.send(); } else if(options.method.toUpperCase() === "POST"){ xhr.open(options.method, options.url) xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded") xhr.send(qs) } xhr.onreadystatechange = function () { if (xhr.readyState === 4 && xhr.status === 200) { var result = JSON.parse(xhr.responseText) options.success(result); } } }
最后測試一下是否能成功~
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>測試界面</title> <script src="itheima.js"></script> </head> <body> <script> itheima({ method:"GET", url:"http://www.liulongbin.top:3006/api/getbooks", data:{ id:1 }, success:function(res){ console.log(res); } }); </script> </body> </html>
總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
微信小程序picker組件下拉框選擇input輸入框的實(shí)例
這篇文章主要介紹了微信小程序picker組件下拉框選擇input輸入框的實(shí)例的相關(guān)資料,希望通過本文能幫助到大家,需要的朋友可以參考下2017-09-09Bootstrap開發(fā)實(shí)戰(zhàn)之響應(yīng)式輪播圖
這篇文章主要為大家詳細(xì)介紹了Bootstrap開發(fā)實(shí)戰(zhàn)之響應(yīng)式輪播圖,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-06-06layui 中select下拉change事件失效的解決方法
今天小編就為大家分享一篇layui 中select下拉change事件失效的解決方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-09-09js設(shè)置document.domain實(shí)現(xiàn)跨域的注意點(diǎn)分析
這篇文章主要介紹了js設(shè)置document.domain實(shí)現(xiàn)跨域的注意點(diǎn),較為詳細(xì)的分析了document.domain跨域的相關(guān)技巧,需要的朋友可以參考下2015-05-05JavaScript?中的運(yùn)算符和表達(dá)式介紹(二)
這篇文章主要介紹了JavaScript?中的運(yùn)算符和表達(dá)式介紹,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-09-09精通Javascript系列之?dāng)?shù)值計(jì)算
在JS中如果希望某個(gè)變量包含一個(gè)數(shù)值,那么無需限定其必須是整數(shù)或者是浮點(diǎn)數(shù),下面來個(gè)例子2011-06-06JavaScript必知必會(huì)(九)function 說起 閉包問題
這篇文章主要介紹了JavaScript必知必會(huì)(九)function 說起 閉包問題的相關(guān)資料,需要的朋友可以參考下2016-06-06Javascript的getYear、getFullYear、getUTCFullYear異同分享
getYear、getFullYear、getUTCFullYear都是Javascript的Date對(duì)象的方法函數(shù)2011-11-11