国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

原生js實現ajax請求和JSONP跨域請求操作示例

瀏覽:138日期:2024-05-17 16:16:15

本文實例講述了原生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程序設計有所幫助。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 老妇激情毛片 | 亚洲精品一区二区不卡 | 久久亚洲综合 | 免费国产不卡午夜福在线 | 国产精品成人久久久久 | 91精品国产免费久久国语蜜臀 | 香蕉tv亚洲专区在线观看 | 三级中文字幕 | 国产成人91一区二区三区 | 欧美日韩在线观看视频 | 一级毛片在线免费视频 | 国产精品久久久久久一区二区三区 | 国产精品激情丝袜美女 | 性理论片 | 极品美女户外勾搭无套 | 日鲁夜鲁鲁狠狠综合视频 | 久久亚洲国产中v天仙www | 国产成人免费 | 亚洲精品国产一区二区三区在 | 日韩精品一二三区 | 亚洲丝袜另类 | 免费人成观看在线网 | 美女被cao免费看在线看网站 | 亚洲精品资源在线 | 一级一片免费视频播放 | 精品国产90后在线观看 | 亚洲一区二区免费视频 | 成人做爰视频www在线观看 | 亚洲国产精品ⅴa在线观看 亚洲国产精品aaa一区 | 国产精品中文字幕在线观看 | 午夜爽爽 | 免费一级欧美大片视频在线 | 国产一区国产二区国产三区 | a毛片免费全部在线播放毛 a毛片免费视频 | 99精品高清不卡在线观看 | 国产一区二区三区四区波多野结衣 | 久久精品国产影库免费看 | 一级做性色a爰片久久毛片 一级做性色a爰片久久毛片免费 | 永久在线 | 一级毛片免费观看不卡的 | 国产成人综合手机在线播放 |