原生js實現ajax請求和JSONP跨域請求操作示例
時間:2020-03-14來源:電腦系統城作者:電腦系統城
本文實例講述了原生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)
- }
- })
-
更多關于JavaScript相關內容感興趣的讀者可查看本站專題:《JavaScript中ajax操作技巧總結》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結》
希望本文所述對大家JavaScript程序設計有所幫助。
相關信息