使用JavaScript?定義自己的ajax函數(shù)
由于用原生js的方式發(fā)起的網(wǎng)絡(luò)請(qǐng)求,都是以查詢字符串的形式,提交給服務(wù)器的,用戶以對(duì)象的形式提交參數(shù)的話會(huì)比較方便,所以需要把用戶傳遞過(guò)來(lái)的參數(shù)對(duì)象進(jìn)行處理,定義resolveData的函數(shù),設(shè)置形參接收參數(shù),遍歷里面的對(duì)象,把鍵和值用=的方式進(jìn)行拼接,然后把所得的值添加進(jìn)空的數(shù)組即可;最后用&符號(hào)把數(shù)組的每一項(xiàng)進(jìn)行分割,并返回;定義itheima函數(shù),設(shè)置形參用于接收用戶傳遞過(guò)來(lái)的配置對(duì)象參數(shù),創(chuàng)建xhr對(duì)象,把傳遞過(guò)來(lái)的參數(shù)傳遞給處理參數(shù)的函數(shù),把得到的返回值,給一個(gè)變量,由于是不同的請(qǐng)求,所以要進(jìn)行判斷,首先是GET請(qǐng)求,判斷參數(shù)里面的method是否全等于GET,由于傳遞過(guò)來(lái)的參數(shù)有可能是小寫,所以通過(guò)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)聽(tīng)事件即可;
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);
}
}
}
最后測(cè)試一下是否能成功~
<!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>測(cè)試界面</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é)
本篇文章就到這里了,希望能夠給你帶來(lái)幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
layui問(wèn)題之模擬table表格中的選中按鈕選中事件的方法
今天小編就為大家分享一篇layui問(wèn)題之模擬table表格中的選中按鈕選中事件的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09
利用ASP發(fā)送和接收XML數(shù)據(jù)的處理方法與代碼
利用ASP發(fā)送和接收XML數(shù)據(jù)的處理方法與代碼...2007-11-11
跨域?yàn)g覽器設(shè)置解決前端跨域問(wèn)題
這篇文章主要為大家介紹了前端跨域?yàn)g覽器設(shè)置解決前端跨域問(wèn)題的方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07
JS判斷鼠標(biāo)進(jìn)入容器的方向與window.open新窗口被攔截的問(wèn)題
這篇文章主要給大家介紹了利用Javascript判斷鼠標(biāo)進(jìn)入容器方向的方法,以及window.open新窗口被攔截的問(wèn)題分析,文中給出了詳細(xì)圖文介紹和示例代碼,相信對(duì)大家的理解和學(xué)習(xí)具有一定的參考借鑒價(jià)值,下面來(lái)一起看看吧。2016-12-12
JavaScript函數(shù)定義方法實(shí)例詳解
這篇文章主要介紹了JavaScript函數(shù)定義方法,結(jié)合實(shí)例形式較為詳細(xì)的分析了javascript函數(shù)的聲明、定義、調(diào)用等原理與常見(jiàn)操作技巧,需要的朋友可以參考下2019-03-03
js驗(yàn)證框架之RealyEasy驗(yàn)證詳解
這篇文章主要為大家詳細(xì)介紹了js驗(yàn)證框架之RealyEasy驗(yàn)證,記錄了RealyEasy驗(yàn)證的使用步驟,感興趣的小伙伴們可以參考一下2016-06-06
javascript事件處理模型實(shí)例說(shuō)明
本文主要介紹IE和火狐在添加刪除事件上的區(qū)別,并給出通用的解決方法,需要的朋友可以參考下。2016-05-05

