原生js實(shí)現(xiàn)ajax請求和JSONP跨域請求操作示例
本文實(shí)例講述了原生js實(shí)現(xiàn)ajax請求和JSONP跨域請求。分享給大家供大家參考,具體如下:
直接上代碼:
const ajax = (params = {}) => { const nowJson = params.jsonp ? jsonp(params) : json(params); function jsonp(params){ //創(chuàng)建script標(biāo)簽并加入到頁面中 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形式傳參 //說明:下面的script加載資源后會(huì)返回一個(gè)自執(zhí)行函數(shù):[callbackName](responseData),這個(gè)形式就是去執(zhí)行一個(gè)函數(shù),函數(shù)的名字是一個(gè)參數(shù) // 同時(shí)在windows對象上定義了這個(gè)函數(shù):[callbackName] = function(responseData){},這時(shí)就會(huì)調(diào)用這個(gè)函數(shù) script.src = params.url + '?' + data; //為了得知此次請求是否成功,設(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) { // 請求方式,默認(rèn)是GET params.type = (params.type || 'GET').toUpperCase(); // 避免有特殊字符,必須格式化傳輸數(shù)據(jù) params.data = formatParams(params.data); var xhr = null; // 實(shí)例化XMLHttpRequest對象 if(window.XMLHttpRequest) { xhr = new XMLHttpRequest(); } else { // IE6及其以下版本 xhr = new ActiveXObjcet('Microsoft.XMLHTTP'); }; // 監(jiān)聽事件,只要 readyState 的值變化,就會(huì)調(diào)用 readystatechange 事件 xhr.onreadystatechange = function() { // readyState屬性表示請求/響應(yīng)過程的當(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開頭的都是成功 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對象響應(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ù):請求方式、請求地址(get方式時(shí),傳輸數(shù)據(jù)是加在地址后的)、是否異步請求(同步請求的情況極少); 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é)》
希望本文所述對大家JavaScript程序設(shè)計(jì)有所幫助。
- JavaScript 解決ajax中parsererror錯(cuò)誤案例詳解
- 如何基于JS實(shí)現(xiàn)Ajax并發(fā)請求的控制詳解
- 利用js實(shí)現(xiàn)Ajax并發(fā)請求限制請求數(shù)量的示例代碼
- vue3.0 加載json的方法(非ajax)
- jQuery+Ajax+js實(shí)現(xiàn)請求json格式數(shù)據(jù)并渲染到html頁面操作示例
- jQuery使用ajax傳遞json對象到服務(wù)端及contentType的用法示例
- js 使用ajax設(shè)置和獲取自定義header信息的方法小結(jié)
- JS解決ajax無法后退的問題記錄
相關(guān)文章
JS中call和apply函數(shù)用法實(shí)例分析
這篇文章主要介紹了JS中call和apply函數(shù)用法,結(jié)合實(shí)例形式較為詳細(xì)的分析了call和apply函數(shù)繼承功能的使用方法、區(qū)別及操作注意事項(xiàng),需要的朋友可以參考下2018-06-06js倒計(jì)時(shí)小實(shí)例(多次定時(shí))
這篇文章主要介紹了js實(shí)現(xiàn)可多次定時(shí)的倒計(jì)時(shí)小實(shí)例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12TypeScript中declare關(guān)鍵字的具體使用
declare關(guān)鍵字用來告訴編譯器,某個(gè)類型是存在的,可以在當(dāng)前文件中使用,本文主要介紹了TypeScript中declare關(guān)鍵字的具體使用,感興趣的可以了解一下2023-10-10基于js與flash實(shí)現(xiàn)的網(wǎng)站flv視頻播放插件代碼
這篇文章主要介紹了基于js與flash實(shí)現(xiàn)的網(wǎng)站flv視頻播放插件代碼,該功能在很多網(wǎng)站上都有著廣泛的應(yīng)用,本文以實(shí)例形式對其進(jìn)行介紹,需要的朋友可以參考下2014-10-10BootStrap.css 在手機(jī)端滑動(dòng)時(shí)右側(cè)出現(xiàn)空白的原因及解決辦法
這篇文章主要介紹了BootStrap.css 在手機(jī)端滑動(dòng)時(shí)右側(cè)出現(xiàn)空白的原因及解決辦法的相關(guān)資料,非常不錯(cuò)具有參考借鑒價(jià)值,需要的朋友可以參考下2016-06-06