原生js實(shí)現(xiàn)ajax請(qǐng)求和JSONP跨域請(qǐng)求操作示例
本文實(shí)例講述了原生js實(shí)現(xiàn)ajax請(qǐng)求和JSONP跨域請(qǐng)求。分享給大家供大家參考,具體如下:
直接上代碼:
const ajax = (params = {}) => {
const nowJson = params.jsonp ? jsonp(params) : json(params);
function jsonp(params){
//創(chuàng)建script標(biāo)簽并加入到頁(yè)面中
var callbackName = params.jsonp;
var head = document.getElementsByTagName('head')[0];
// 設(shè)置傳遞給后臺(tái)的回調(diào)參數(shù)名
params.data['callback'] = callbackName;
var data = formatParams(params.data);
var script = document.createElement('script');
head.appendChild(script);
window[callbackName] = function(jsonData) {
head.removeChild(script);
clearTimeout(script.timer);
window[callbackName] = null;
params.success && params.success(jsonData);
};
//console.log(window[callbackName])
//console.log(params.url + '?' + data)
//url形式傳參
//說(shuō)明:下面的script加載資源后會(huì)返回一個(gè)自執(zhí)行函數(shù):[callbackName](responseData),這個(gè)形式就是去執(zhí)行一個(gè)函數(shù),函數(shù)的名字是一個(gè)參數(shù)
// 同時(shí)在windows對(duì)象上定義了這個(gè)函數(shù):[callbackName] = function(responseData){},這時(shí)就會(huì)調(diào)用這個(gè)函數(shù)
script.src = params.url + '?' + data;
//為了得知此次請(qǐng)求是否成功,設(shè)置超時(shí)處理
if(params.time) {
script.timer = setTimeout(function() {
window[callbackName] = null;
head.removeChild(script);
params.error && params.error({
message: '超時(shí)'
});
}, params.time);
}
}
//格式化參數(shù)
function formatParams(data) {
var arr = [];
for(var name in data) {
arr.push(encodeURIComponent(name) + '=' + encodeURIComponent(data[name]));
};
// 添加一個(gè)隨機(jī)數(shù),防止緩存
arr.push('v=' + random());
return arr.join('&');
}
// 獲取隨機(jī)數(shù)
function random() {
return Math.floor(Math.random() * 10000 + 500);
}
function json(params) {
// 請(qǐng)求方式,默認(rèn)是GET
params.type = (params.type || 'GET').toUpperCase();
// 避免有特殊字符,必須格式化傳輸數(shù)據(jù)
params.data = formatParams(params.data);
var xhr = null;
// 實(shí)例化XMLHttpRequest對(duì)象
if(window.XMLHttpRequest) {
xhr = new XMLHttpRequest();
} else {
// IE6及其以下版本
xhr = new ActiveXObjcet('Microsoft.XMLHTTP');
};
// 監(jiān)聽(tīng)事件,只要 readyState 的值變化,就會(huì)調(diào)用 readystatechange 事件
xhr.onreadystatechange = function() {
// readyState屬性表示請(qǐng)求/響應(yīng)過(guò)程的當(dāng)前活動(dòng)階段,4為完成,已經(jīng)接收到全部響應(yīng)數(shù)據(jù)
if(xhr.readyState == 4) {
var status = xhr.status;
// status:響應(yīng)的HTTP狀態(tài)碼,以2開(kāi)頭的都是成功
if(status >= 200 && status < 300) {
var response = '';
// 判斷接受數(shù)據(jù)的內(nèi)容類型
var type = xhr.getResponseHeader('Content-type');
if(type.indexOf('xml') !== -1 && xhr.responseXML) {
response = xhr.responseXML; //Document對(duì)象響應(yīng)
} else if(type === 'application/json') {
response = JSON.parse(xhr.responseText); //JSON響應(yīng)
} else {
response = xhr.responseText; //字符串響應(yīng)
};
// 成功回調(diào)函數(shù)
params.success && params.success(response);
} else {
params.error && params.error(status);
}
};
};
// 連接和傳輸數(shù)據(jù)
if(params.type == 'GET') {
// 三個(gè)參數(shù):請(qǐng)求方式、請(qǐng)求地址(get方式時(shí),傳輸數(shù)據(jù)是加在地址后的)、是否異步請(qǐng)求(同步請(qǐng)求的情況極少);
xhr.open(params.type, params.url + '?' + params.data, true);
xhr.send(null);
} else {
xhr.open(params.type, params.url, true);
//必須,設(shè)置提交時(shí)的內(nèi)容類型
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded; charset=UTF-8');
// 傳輸數(shù)據(jù)
xhr.send(params.data);
}
}
}
export default ajax;
調(diào)用:
ajax({
jsonp:'JSONP',
url:'http://localhost:8080/test',
data:{},
time:1000,
success:function(data){
console.log(data)
},
error:function(error){
console.log(error)
}
})
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript中ajax操作技巧總結(jié)》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
- JavaScript 解決ajax中parsererror錯(cuò)誤案例詳解
- 如何基于JS實(shí)現(xiàn)Ajax并發(fā)請(qǐng)求的控制詳解
- 利用js實(shí)現(xiàn)Ajax并發(fā)請(qǐng)求限制請(qǐng)求數(shù)量的示例代碼
- vue3.0 加載json的方法(非ajax)
- jQuery+Ajax+js實(shí)現(xiàn)請(qǐng)求json格式數(shù)據(jù)并渲染到html頁(yè)面操作示例
- jQuery使用ajax傳遞json對(duì)象到服務(wù)端及contentType的用法示例
- js 使用ajax設(shè)置和獲取自定義header信息的方法小結(jié)
- JS解決ajax無(wú)法后退的問(wèn)題記錄
相關(guān)文章
javascript將ip地址第四段用星號(hào)代替的兩種方法
javascript將ip地址第四段用星號(hào)代替的方法,需要的朋友可以參考下。2010-03-03
如何創(chuàng)建一個(gè)JavaScript彈出DIV窗口層的效果
我將用最通俗的語(yǔ)言和最簡(jiǎn)潔的代碼給大家演示如何創(chuàng)建一個(gè)JavaScript彈出DIV窗口層的效果2013-09-09
js百度地圖鼠標(biāo)滾輪縮放導(dǎo)致地圖中心點(diǎn)偏移問(wèn)題
本文主要介紹了js百度地圖鼠標(biāo)滾輪縮放導(dǎo)致地圖中心點(diǎn)偏移問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-02-02
Javascript數(shù)據(jù)結(jié)構(gòu)與算法之列表詳解
這篇文章主要介紹了Javascript數(shù)據(jù)結(jié)構(gòu)與算法之列表詳解,本文講解了列表的抽象數(shù)據(jù)類型定義、如何實(shí)現(xiàn)列表類等內(nèi)容,需要的朋友可以參考下2015-03-03
JS獲取指定月份的天數(shù)兩種實(shí)現(xiàn)方法
這篇文章主要介紹了JS獲取指定月份的天數(shù)兩種實(shí)現(xiàn)方法,需要的朋友可以參考下2018-06-06
一覽畫面點(diǎn)擊復(fù)選框后獲取多個(gè)id值的方法
這篇文章主要介紹了在一覽畫面點(diǎn)擊復(fù)選框后獲取多個(gè)id值的方法,前臺(tái)采用js技術(shù)后臺(tái)采用java技術(shù)實(shí)現(xiàn)的,邏輯清晰,非常不錯(cuò),具有參考借鑒價(jià)值,感興趣的朋友一起看看吧2016-05-05
JS對(duì)象與json字符串格式轉(zhuǎn)換實(shí)例
這篇文章主要介紹了JS對(duì)象與json字符串格式轉(zhuǎn)換方法,以實(shí)例的形式詳細(xì)講述了js對(duì)象與json字符串格式轉(zhuǎn)換的技巧,需要的朋友可以參考下2014-10-10
JS中判斷字符串中出現(xiàn)次數(shù)最多的字符及出現(xiàn)的次數(shù)的簡(jiǎn)單實(shí)例
下面小編就為大家?guī)?lái)一篇JS中判斷字符串中出現(xiàn)次數(shù)最多的字符及出現(xiàn)的次數(shù)的簡(jiǎn)單實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-06-06
TypeScript魔法堂之枚舉的超實(shí)用手冊(cè)
這篇文章主要介紹了TypeScript魔法堂之枚舉的超實(shí)用手冊(cè),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10
JavaScript中:表達(dá)式和語(yǔ)句的區(qū)別[譯]
本文要講的是JavaScript中非常重要的兩個(gè)知識(shí)點(diǎn):表達(dá)式(expressions)和語(yǔ)句(statements)之間的區(qū)別2012-09-09

