小編給大家分享一下原生js如何實現ajax請求和JSONP跨域請求,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
直接上代碼:
const ajax = (params = {}) => {
const nowJson = params.jsonp ? jsonp(params) : json(params);
function jsonp(params){
//創建script標簽并加入到頁面中
var callbackName = params.jsonp;
var head = document.getElementsByTagName('head')[0];
// 設置傳遞給后臺的回調參數名
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形式傳參
//說明:下面的script加載資源后會返回一個自執行函數:[callbackName](responseData),這個形式就是去執行一個函數,函數的名字是一個參數
// 同時在windows對象上定義了這個函數:[callbackName] = function(responseData){},這時就會調用這個函數
script.src = params.url + '?' + data;
//為了得知此次請求是否成功,設置超時處理
if(params.time) {
script.timer = setTimeout(function() {
window[callbackName] = null;
head.removeChild(script);
params.error && params.error({
message: '超時'
});
}, params.time);
}
}
//格式化參數
function formatParams(data) {
var arr = [];
for(var name in data) {
arr.push(encodeURIComponent(name) + '=' + encodeURIComponent(data[name]));
};
// 添加一個隨機數,防止緩存
arr.push('v=' + random());
return arr.join('&');
}
// 獲取隨機數
function random() {
return Math.floor(Math.random() * 10000 + 500);
}
function json(params) {
// 請求方式,默認是GET
params.type = (params.type || 'GET').toUpperCase();
// 避免有特殊字符,必須格式化傳輸數據
params.data = formatParams(params.data);
var xhr = null;
// 實例化XMLHttpRequest對象
if(window.XMLHttpRequest) {
xhr = new XMLHttpRequest();
} else {
// IE6及其以下版本
xhr = new ActiveXObjcet('Microsoft.XMLHTTP');
};
// 監聽事件,只要 readyState 的值變化,就會調用 readystatechange 事件
xhr.onreadystatechange = function() {
// readyState屬性表示請求/響應過程的當前活動階段,4為完成,已經接收到全部響應數據
if(xhr.readyState == 4) {
var status = xhr.status;
// status:響應的HTTP狀態碼,以2開頭的都是成功
if(status >= 200 && status < 300) {
var response = '';
// 判斷接受數據的內容類型
var type = xhr.getResponseHeader('Content-type');
if(type.indexOf('xml') !== -1 && xhr.responseXML) {
response = xhr.responseXML; //Document對象響應
} else if(type === 'application/json') {
response = JSON.parse(xhr.responseText); //JSON響應
} else {
response = xhr.responseText; //字符串響應
};
// 成功回調函數
params.success && params.success(response);
} else {
params.error && params.error(status);
}
};
};
// 連接和傳輸數據
if(params.type == 'GET') {
// 三個參數:請求方式、請求地址(get方式時,傳輸數據是加在地址后的)、是否異步請求(同步請求的情況極少);
xhr.open(params.type, params.url + '?' + params.data, true);
xhr.send(null);
} else {
xhr.open(params.type, params.url, true);
//必須,設置提交時的內容類型
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded; charset=UTF-8');
// 傳輸數據
xhr.send(params.data);
}
}
}
export default ajax;調用:
ajax({
jsonp:'JSONP',
url:'http://localhost:8080/test',
data:{},
time:1000,
success:function(data){
console.log(data)
},
error:function(error){
console.log(error)
}
})以上是“原生js如何實現ajax請求和JSONP跨域請求”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。