系統城裝機大師 - 唯一官網:www.farandoo.com!

當前位置:首頁 > 網絡編程 > JavaScript > 詳細頁面

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

時間:2020-03-14來源:電腦系統城作者:電腦系統城

本文實例講述了原生js實現ajax請求和JSONP跨域請求。分享給大家供大家參考,具體如下:

直接上代碼:


 
  1. const ajax = (params = {}) => {
  2. const nowJson = params.jsonp ? jsonp(params) : json(params);
  3. function jsonp(params){
  4. //創建script標簽并加入到頁面中
  5. var callbackName = params.jsonp;
  6. var head = document.getElementsByTagName('head')[0];
  7. // 設置傳遞給后臺的回調參數名
  8. params.data['callback'] = callbackName;
  9. var data = formatParams(params.data);
  10. var script = document.createElement('script');
  11. head.appendChild(script);
  12.  
  13. window[callbackName] = function(jsonData) {
  14. head.removeChild(script);
  15. clearTimeout(script.timer);
  16. window[callbackName] = null;
  17. params.success && params.success(jsonData);
  18. };
  19. //console.log(window[callbackName])
  20. //console.log(params.url + '?' + data)
  21.  
  22. //url形式傳參
  23. //說明:下面的script加載資源后會返回一個自執行函數:[callbackName](responseData),這個形式就是去執行一個函數,函數的名字是一個參數
  24. // 同時在windows對象上定義了這個函數:[callbackName] = function(responseData){},這時就會調用這個函數
  25. script.src = params.url + '?' + data;
  26.  
  27. //為了得知此次請求是否成功,設置超時處理
  28. if(params.time) {
  29. script.timer = setTimeout(function() {
  30. window[callbackName] = null;
  31. head.removeChild(script);
  32. params.error && params.error({
  33. message: '超時'
  34. });
  35. }, params.time);
  36. }
  37. }
  38. //格式化參數
  39. function formatParams(data) {
  40. var arr = [];
  41. for(var name in data) {
  42. arr.push(encodeURIComponent(name) + '=' + encodeURIComponent(data[name]));
  43. };
  44.  
  45. // 添加一個隨機數,防止緩存
  46. arr.push('v=' + random());
  47. return arr.join('&');
  48. }
  49.  
  50. // 獲取隨機數
  51. function random() {
  52. return Math.floor(Math.random() * 10000 + 500);
  53. }
  54. function json(params) {
  55. // 請求方式,默認是GET
  56. params.type = (params.type || 'GET').toUpperCase();
  57. // 避免有特殊字符,必須格式化傳輸數據
  58. params.data = formatParams(params.data);
  59. var xhr = null;
  60.  
  61. // 實例化XMLHttpRequest對象
  62. if(window.XMLHttpRequest) {
  63. xhr = new XMLHttpRequest();
  64. } else {
  65. // IE6及其以下版本
  66. xhr = new ActiveXObjcet('Microsoft.XMLHTTP');
  67. };
  68.  
  69. // 監聽事件,只要 readyState 的值變化,就會調用 readystatechange 事件
  70. xhr.onreadystatechange = function() {
  71. // readyState屬性表示請求/響應過程的當前活動階段,4為完成,已經接收到全部響應數據
  72. if(xhr.readyState == 4) {
  73. var status = xhr.status;
  74. // status:響應的HTTP狀態碼,以2開頭的都是成功
  75. if(status >= 200 && status < 300) {
  76. var response = '';
  77. // 判斷接受數據的內容類型
  78. var type = xhr.getResponseHeader('Content-type');
  79. if(type.indexOf('xml') !== -1 && xhr.responseXML) {
  80. response = xhr.responseXML; //Document對象響應
  81. } else if(type === 'application/json') {
  82. response = JSON.parse(xhr.responseText); //JSON響應
  83. } else {
  84. response = xhr.responseText; //字符串響應
  85. };
  86. // 成功回調函數
  87. params.success && params.success(response);
  88. } else {
  89. params.error && params.error(status);
  90. }
  91. };
  92. };
  93.  
  94. // 連接和傳輸數據
  95. if(params.type == 'GET') {
  96. // 三個參數:請求方式、請求地址(get方式時,傳輸數據是加在地址后的)、是否異步請求(同步請求的情況極少);
  97. xhr.open(params.type, params.url + '?' + params.data, true);
  98. xhr.send(null);
  99. } else {
  100. xhr.open(params.type, params.url, true);
  101. //必須,設置提交時的內容類型
  102. xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded; charset=UTF-8');
  103. // 傳輸數據
  104. xhr.send(params.data);
  105. }
  106. }
  107. }
  108. export default ajax;
  109.  

調用:


 
  1. ajax({
  2. jsonp:'JSONP',
  3. url:'http://localhost:8080/test',
  4. data:{},
  5. time:1000,
  6. success:function(data){
  7. console.log(data)
  8. },
  9. error:function(error){
  10. console.log(error)
  11. }
  12. })
  13.  

更多關于JavaScript相關內容感興趣的讀者可查看本站專題:《JavaScript中ajax操作技巧總結》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結》

希望本文所述對大家JavaScript程序設計有所幫助。

分享到:

相關信息

系統教程欄目

欄目熱門教程

人氣教程排行

站長推薦

熱門系統下載

jlzzjlzz亚洲乱熟在线播放