自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

項(xiàng)目實(shí)踐 - Axios進(jìn)階封裝

開發(fā) 項(xiàng)目管理
axios二次封裝:就是把大部分接口公共的參數(shù)配置提取出來統(tǒng)一進(jìn)行處理。

[[403088]]

 axios二次封裝解決了什么問題?(項(xiàng)目常用)

axios二次封裝:就是把大部分接口公共的參數(shù)配置提取出來統(tǒng)一進(jìn)行處理。

1、代碼封裝,重用性高,減少代碼量,減低維護(hù)難度。

2、統(tǒng)一處理一些常規(guī)的問題一勞永逸,如http錯(cuò)誤。

3、攔截請(qǐng)求和響應(yīng),提前對(duì)數(shù)據(jù)進(jìn)行處理,如獲取token,修改配置項(xiàng)。

Axios基礎(chǔ)配置- 實(shí)踐

1) 全局的 axios 默認(rèn)值

  1. axios.defaults.baseURL = 'https://api.example.com'
  2. axios.defaults.headers.common['Authorization'] = AUTH_TOKEN; 
  3. axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded'

2) 自定義實(shí)例默認(rèn)值

  1. // 創(chuàng)建實(shí)例時(shí)設(shè)置配置的默認(rèn)值 
  2. var instance = axios.create({ 
  3.   baseURL: 'https://api.example.com' 
  4. }); 
  5.  
  6. // 在實(shí)例已創(chuàng)建后修改默認(rèn)值 
  7. instance.defaults.headers.common['Authorization'] = AUTH_TOKEN; 

3) 區(qū)分環(huán)境配置

  1. let env = "dev"
  2. switch (env) { 
  3.     case 'dev'
  4.         axios.defaults.baseURL = "http://127.0.0.1:8888"
  5.         break; 
  6.     case 'test'
  7.         axios.defaults.baseURL = "http://114.27.34.1:8888"
  8.         break; 
  9.     case 'pro'
  10.         axios.defaults.baseURL = "http://api.zhufeng.cn"
  11.         break; 

4) 數(shù)據(jù)格式配置

  1. axios.defaults.headers['Content-Type'] = 'application/x-www-form-urlencoded'
  2. // axios.defaults.headers.common['Content-Type'] = 'application/x-www-form-urlencoded'
  3. // axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded'
  4. axios.defaults.transformRequest = function (data, headers) { 
  5.     let ContentType = headers['Content-Type'] || headers.common['Content-Type'] || headers.post['Content-Type'] || 'application/json'
  6.  
  7.     if (ContentType === "application/json") { 
  8.         return JSON.stringify(data); 
  9.     } 
  10.  
  11.     if (ContentType === "application/x-www-form-urlencoded") { 
  12.         return Qs.stringify(data); 
  13.     } 
  14.     return data; 
  15. }; 

項(xiàng)目實(shí)踐-數(shù)據(jù)格式

  1. service.interceptors.request.use( 
  2.   (config) => { 
  3.     // 開發(fā)環(huán)境引入包裝api 
  4.     config.url = `${BASE_URL}${config.url}`; 
  5.     config.headers['Cache-Control'] = 'no-cache,no-store,must-revalidate,max-age=-1,private'
  6.     // post請(qǐng)求并且需要將data以form data 形式傳給后端 需要傳一個(gè)formType為true boolean 
  7.     if (config.method === 'post' && config.formType === true) { 
  8.       config.headers['Content-Type'] = 'application/x-www-form-urlencoded;charset=UTF-8'
  9.       config.data = qs.stringify(config.data); 
  10.     } 
  11.     return config; 
  12.   }, 
  13.   (error) => { 
  14.     // Do something with request error 
  15.     Promise.reject(error); 
  16.   } 
  17. ); 

5) 攔截器

  1. // 添加請(qǐng)求攔截器 
  2. axios.interceptors.request.use(function (config) { 
  3.     // 在發(fā)送請(qǐng)求之前做些什么 
  4.     return config; 
  5. }, function (error) { 
  6.     // 對(duì)請(qǐng)求錯(cuò)誤做些什么 
  7.     return Promise.reject(error); 
  8. }); 
  9.  
  10. // 添加響應(yīng)攔截器 
  11. axios.interceptors.response.use(function (response) { 
  12.     // 對(duì)響應(yīng)數(shù)據(jù)做點(diǎn)什么 
  13.     return response; 
  14. }, function (error) { 
  15.     // 對(duì)響應(yīng)錯(cuò)誤做點(diǎn)什么 
  16.     return Promise.reject(error); 
  17. }); 

6) 響應(yīng)的錯(cuò)誤處理封裝

interceptor作用就是攔截,可以針對(duì)請(qǐng)求參數(shù)和響應(yīng)結(jié)果進(jìn)行攔截處理,一般在項(xiàng)目當(dāng)中,主要針對(duì)接口常規(guī)報(bào)錯(cuò)、網(wǎng)絡(luò)報(bào)錯(cuò)、系統(tǒng)超時(shí)、權(quán)限認(rèn)證等做攔截處理。

  1. axios.interceptors.response.use(function (response) { 
  2.     // 把獲取的響應(yīng)主體信息返回 
  3.     return response.data; 
  4. }, function (reason) { 
  5.     // 失敗:網(wǎng)絡(luò)、狀態(tài)碼(Axios失敗) 
  6.     let response = reason.response; 
  7.     if (response) { 
  8.         // 狀態(tài)碼不是2開頭的 
  9.         switch (response.status) { 
  10.             //400 參數(shù) 
  11.             //401/403 Token 
  12.             //404 地址 
  13.             //500/503 服務(wù)器 
  14.         } 
  15.     } else { 
  16.         // 網(wǎng)絡(luò) / (超時(shí) / 中斷請(qǐng)求  -> code: "ECONNABORTED") ... 
  17.         if (reason && reason.code === "ECONNABORTED") {} 
  18.         if (!navigator.onLine) {} 
  19.     } 
  20.     return reason; 
  21. }); 

一般項(xiàng)目,這樣就沒問題了,一套公共的參數(shù)配置。剩下都是請(qǐng)求的時(shí)候單獨(dú)再配置即可。

Axios配置- 原理與源碼

1) HTTP 攔截器的設(shè)計(jì)與實(shí)現(xiàn)

對(duì)于大多數(shù) SPA 應(yīng)用程序來說, 通常會(huì)使用 token 進(jìn)行用戶的身份認(rèn)證。這就要求在認(rèn)證通過后,我們需要在每個(gè)請(qǐng)求上都攜帶認(rèn)證信息。如果在考慮對(duì)響應(yīng)進(jìn)行統(tǒng)一處理的話,我們的 request 函數(shù)將變得越來越龐大,也越來越難維護(hù)。那么對(duì)于這個(gè)問題,Axios 為我們提供了解決方案 —— 攔截器。

Axios 是一個(gè)基于 Promise 的 HTTP 客戶端,而 HTTP 協(xié)議是基于請(qǐng)求和響應(yīng):

所以 Axios 提供了請(qǐng)求攔截器和響應(yīng)攔截器來分別處理請(qǐng)求和響應(yīng)。

1) 請(qǐng)求攔截器:該類攔截器的作用是在請(qǐng)求發(fā)送前統(tǒng)一執(zhí)行某些操作,比如在請(qǐng)求頭中添加 token 字段。

2) 響應(yīng)攔截器:該類攔截器的作用是在接收到服務(wù)器響應(yīng)后統(tǒng)一執(zhí)行某些操作,比如發(fā)現(xiàn)響應(yīng)狀態(tài)碼為 401 時(shí),自動(dòng)跳轉(zhuǎn)到登錄頁。

2) 二次封裝配置代碼:(參考)

  1. import axios from 'axios'
  2. import qs from 'qs'
  3. /* 
  4.  * 根據(jù)環(huán)境變量區(qū)分接口的默認(rèn)地址  
  5. */ 
  6. switch (process.env.NODE_ENV) { 
  7.     case "production"
  8.         axios.defaults.baseURL = "http://api.zhufengpeixun.cn"
  9.         break; 
  10.     case "test"
  11.         axios.defaults.baseURL = "http://192.168.20.12:8080"
  12.         break; 
  13.     default
  14.         axios.defaults.baseURL = "http://127.0.0.1:3000"
  15.  
  16. /* 
  17.  * 設(shè)置超時(shí)時(shí)間和跨域是否允許攜帶憑證  
  18. */ 
  19. axios.defaults.timeout = 10000; 
  20. axios.defaults.withCredentials = true
  21.  
  22. /* 
  23.  * 設(shè)置請(qǐng)求傳遞數(shù)據(jù)的格式(看服務(wù)器要求什么格式) 
  24.  * x-www-form-urlencoded 
  25. */ 
  26. axios.defaults.headers['Content-Type'] = 'application/x-www-form-urlencoded'
  27. axios.defaults.transformRequest = data => qs.stringify(data); 
  28.  
  29. /* 
  30.  * 設(shè)置請(qǐng)求攔截器  
  31.  * 客戶端發(fā)送請(qǐng)求 - > [請(qǐng)求攔截器] - > 服務(wù)器 
  32. * TOKEN校驗(yàn)(JWT):接收服務(wù)器返回的token,存儲(chǔ)到vuex/本地存儲(chǔ)中,每一次向服務(wù)器發(fā)請(qǐng)求,我們應(yīng)該把token帶上 
  33. */ 
  34. axios.interceptors.request.use(config => { 
  35.     // 攜帶上token 
  36.     let token = localStorage.getItem('token'); 
  37.     token && (config.headers.Authorization = token); 
  38.     return config; 
  39. }, error => { 
  40.    return Promise.reject(error); 
  41. }); 
  42.  
  43. /* 
  44.  * 響應(yīng)攔截器  
  45.  * 服務(wù)器返回信息  -> [攔截的統(tǒng)一處理] -> 客戶端JS獲取到信息 
  46. */ 
  47. axios.defaults.validateStatus = status => { 
  48.     // 自定義響應(yīng)成功的HTTP狀態(tài)碼 
  49.     return /^(2|3)\d{2}$/.test(status); 
  50. }; 
  51. axios.interceptors.response.use(response => { 
  52.     return response.data; 
  53. }, error => { 
  54.     let { 
  55.         response 
  56.     } = error; 
  57.     if (response) { 
  58.         //=>服務(wù)器最起碼返回結(jié)果了 
  59.         switch (response.status) { 
  60.             case 401: //=>權(quán)限 
  61.                 break; 
  62.             case 403: //=>服務(wù)器拒絕執(zhí)行(token過期) 
  63.                 break; 
  64.             case 404: //=>找不到頁面  
  65.                 break; 
  66.         } 
  67.     } else { 
  68.         //=>服務(wù)器連結(jié)果都沒有返回 
  69.         if (!window.navigator.onLine) { 
  70.             // 斷網(wǎng)處理:可以跳轉(zhuǎn)到斷網(wǎng)頁面 
  71.             return
  72.         } 
  73.         return Promise.reject(error); 
  74.     } 
  75. }); 
  76. export default axios; 

 【編輯推薦】

 

責(zé)任編輯:姜華 來源: 前端學(xué)苑
相關(guān)推薦

2022-04-22 10:51:45

TSaxios前端

2021-07-27 14:50:15

axiosHTTP前端

2023-10-07 14:25:14

2020-10-19 19:05:20

VueAxiosAPI

2020-07-17 19:55:50

Vue前端性能優(yōu)化

2019-11-22 15:27:07

技術(shù)漏洞管理網(wǎng)絡(luò)

2019-11-24 23:39:01

漏洞管理漏洞風(fēng)險(xiǎn)

2020-05-06 09:25:10

微前端qiankun架構(gòu)

2020-06-12 07:00:00

Web開發(fā)項(xiàng)目

2017-08-08 10:01:20

項(xiàng)目管理敏捷實(shí)踐團(tuán)隊(duì)

2023-09-05 08:21:07

項(xiàng)目CICD場(chǎng)景

2017-04-28 10:57:52

IT信息化服務(wù)器云計(jì)算

2022-09-28 12:39:46

axios攔截器

2022-12-30 11:46:00

數(shù)據(jù)中臺(tái)

2021-03-02 08:00:00

項(xiàng)目管理組織工具

2023-08-28 07:28:41

項(xiàng)目領(lǐng)域?qū)?/a>充血模型

2021-06-10 16:05:17

DevOpsGitLab極狐

2024-04-18 09:20:43

PostgreSQL關(guān)系型數(shù)據(jù)庫數(shù)據(jù)庫管理系統(tǒng)

2025-03-07 09:01:14

商品模塊接口項(xiàng)目

2021-01-06 07:59:19

Jenkins Job DslJenkins實(shí)踐
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)