主頁 > 移動端開發 > vue專案封裝請求完整版(帶有詳細說明)

vue專案封裝請求完整版(帶有詳細說明)

2021-02-21 10:22:09 移動端開發

先介紹下整體檔案目錄,以及需要改動的檔案,做到心里有數:
(為了方便大家直接復制使用,有些創建專案自帶的我也會復制下來,做了修改的地方會具體說明)
在這里插入圖片描述
上面紅色框框包起來的檔案就是新增或者修改的地方,下面會逐一做詳細說明

1.創建一個serve檔案夾,并創建一個index.js檔案,里面寫axios相關的配置

import axios from 'axios'     //需要先下載依賴:  npm install axios
import md5 from 'js-md5'      //需要先下載依賴:  npm install js-md5   這個東西是用來加密的,根據實際需要添加
var Axios = axios.create({     //創建axios請求
    baseURL: '/',
    timeout: 10000,           //設定請求超時時間
    responseType: 'json',
    withCredentials: true,  // 是否允許帶cookie這些
    crossDomain: true,
    headers: {
      'Content-Type': 'application/json;charset=utf-8'
    }
  })
  Axios.interceptors.request.use(    //設定請求攔截器,就是在發送請求前做一些資料操作等
    config => {
      if (config.data && config.data.body) {
        const stringBody = JSON.stringify(config.data.body)
        Object.assign(config.data, {    //這里的操作就是將下面的三個屬性添加在每個請求引數里
          id: md5(stringBody),          //stringBody就是請求的引數,通過md5進行加密轉換
          sign: md5(stringBody + new Date().getTime()),
          timestamp: new Date().getTime()
        })
      }
      return config       //最后一定要將配置return出去
    },
    error => {          //請求錯誤時回傳錯誤資訊
      return Promise.reject(error.data.error.message)
    }
  )
Axios.interceptors.response.use(         // 回傳狀態判斷(添加回應攔截器)
    res => {
      return res.data.body
    },
    error => {
      console.log(error)
    }
  )
  //  下面是封裝的請求,并暴露出去,方便其它檔案匯入使用
  // get請求           
export const GET = url => {
    return body =>
      Axios.get(url, {
        params: body
      })
  }
  console.log(GET);
  // post請求
  export const POST = (
    url,
    config = {
      showLoading: true
    }
  ) => {
    return body => Axios.post(url, body, config)
  }
  export const PUT = (
    url,
    config = {
      showLoading: true
    }
  ) => {
    return body => Axios.put(url, body, config)
  }
  
  export const DELETE = url => {
    return body =>
      Axios.delete(url, {
        params: body
      })
  }
  
  export default Axios
  

2.在專案根目錄創建三個不同的專案環境組態檔,這個在vue.cli官方檔案有說明

整體檔案位置在本文最上面可以看到

先創建一個 .env.dev 檔案,  //這個是開發環境配置
檔案內容:   
NODE_ENV="production"
VUE_APP_ENV="dev"
再創建一個 .env.test 檔案, //這個是測驗環境配置
檔案內容:
NODE_ENV="production"
VUE_APP_ENV="test"
最后創建一個 .env.production 檔案, //這個是生產環境配置
檔案內容:
NODE_ENV="production"
VUE_APP_ENV="pro"

3.創建一個config檔案夾,做環境和域名的配置:

1.先在該檔案夾創建一個 apiConfig.js 檔案,做不同環境的域名配置:(下面域名都是假的,根據自己實際情況修改)

export default {
    dev: {
      ApiUrl: 'http://123.57.67.20:000000'
    },
    test: {
      ApiUrl: 'https://aaaaaaaaaaaaaa.com'
    },
    prod: {
      ApiUrl: 'https://bbbbbbbbbbbbbb.com'
    }
  }
  

2.在該檔案夾下繼續創建一個index.js檔案:

import { GET, POST, PUT, DELETE } from '@/server'    //從server檔案夾的index檔案中匯入這4種請求方式
import appConfig from '@/config/apiConfig'    //匯入上面的環境域名組態檔
const { ApiUrl } = appConfig[process.env.VUE_APP_ENV ? process.env.VUE_APP_ENV : 'dev']   
//根據不同環境配置不同環境下的apiurl并在請求中使用
export { GET, POST, PUT, DELETE, ApiUrl }   //匯出請求方式

4.創建一個api檔案夾,用于存放開發中需要使用的請求:

1.在api檔案夾下再創建一個modules檔案夾
在此檔案夾記憶體放開發中的請求介面:(請求介面一般根據不同分類存放在多個js檔案內)
例如我創建了一個board.js 檔案,用于存放一些介面:

import { POST, ApiUrl } from '@/config/index'    //匯入對應的請求方式以及環境配置apiurl
// 獲取.....資料
const getAgricultureData = POST(`${ApiUrl}/api/backapp.......`)    //以此post介面為例子
const intelligentBreedingController = year => {
  return GET(`${ApiUrl}/gateway/api/backapp/indust.....dfwf/${year}`)()
}   //以此get介面為例子
export default {
  getAgricultureData: getAgricultureData   //匯出post介面請求方法名
  intelligentBreedingController //匯出get介面請求方法名  因為屬性名和屬性值一樣時可以簡寫一個 ,所以這里可以直接寫一個名字就行
} 

2.同時在modules檔案夾下創建一個index.js檔案,用于對匯出介面檔案做處理

const files = require.context('.', false, /\.js$/)   //匹配js結尾的檔案,也就是要匹配modules檔案夾下的介面檔案
const modules = []
files.keys().forEach(key => {   //實際中會根據分類創建多個介面檔案,所以這里做遍歷得到每個介面檔案
  if (key === './index.js') return    //判斷如果是當前這個index.js檔案就return出去
  const item = files(key).default     //如果是介面檔案就全部放在modules檔案內并匯出去
  modules.push(item)
})
export default modules

3.在api這個檔案夾內創建一個index.js檔案,用于得到介面檔案中所有具體的api介面

import modules from './modules'    
const Api = {}
modules.map(m => {     //得到每個介面并匯出
  Object.assign(Api, m)
})
export default Api

5.在main.js檔案中匯入axios,并將每個請求介面都掛載到vue上,

import Vue from 'vue'
import App from './App.vue'
import router from './router'
import store from './store'
import Api from '@/api'    //匯入上面api檔案下的所有請求介面

Vue.config.productionTip = false
Vue.prototype.$axios = Api   //這里就是將請求掛載在vue原型上,方便后面直接通過this.$axios...呼叫介面
console.log(Vue.prototype);
new Vue({
  router,
  store,
  render: h => h(App)
}).$mount('#app')

6.具體使用方法:

1.以post請求方式的介面為例:

 methods: {
    async getAgricultureData() {   //這里是配置請求引數
      const params = {
        body: {
          params: {
            years: 2021,
          },
        },
      };
      try {
        const res = await this.$axios.getAgricultureData(params);  //發送請求
        console.log(res);   //請求成功時的操作
      } catch (error) {
        console.log(error);   //請求失敗時的操作
      }
    },
  },

2.以get請求方式的介面為例:

 methods: {
    async intelligentBreedingController() {
      const params = this.selectYear    //創建引數
      try {
        const res = await this.$axios.intelligentBreedingController(params)   //發送請求
        console.log(res);   //請求成功時的操作
      } catch (error) {    //請求失敗時的操作
        if (typeof error == 'string') {    //這里對請求失敗時回傳的錯誤型別做了判斷,根據實際情況來
          this.$message.error(error)
        } else {
          this.$message.error('資料獲取失敗')  
        }
      }
 }

請求方式就像上面寫的一樣,需要注意的是,在呼叫介面時,并沒有在.vue檔案中進行匯入,
這正是因為我們已經做了全域掛載,只需要直接使用,最后就是在哪里需要呼叫,呼叫methods中的
方法名即可.例如上面例子在created()宣告周期函式中呼叫對應的方法名

轉載請註明出處,本文鏈接:https://www.uj5u.com/yidong/261753.html

標籤:其他

上一篇:ACM-ICPC 2018 南京賽區網路預賽 J.sum

下一篇:2021牛客寒假演算法基礎集訓營4,簽到題AGJ

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 【從零開始擼一個App】Dagger2

    Dagger2是一個IOC框架,一般用于Android平臺,第一次接觸的朋友,一定會被搞得暈頭轉向。它延續了Java平臺Spring框架代碼碎片化,注解滿天飛的傳統。嘗試將各處代碼片段串聯起來,理清思緒,真不是件容易的事。更不用說還有各版本細微的差別。 與Spring不同的是,Spring是通過反射 ......

    uj5u.com 2020-09-10 06:57:59 more
  • Flutter Weekly Issue 66

    新聞 Flutter 季度調研結果分享 教程 Flutter+FaaS一體化任務編排的思考與設計 詳解Dart中如何通過注解生成代碼 GitHub 用對了嗎?Flutter 團隊分享如何管理大型開源專案 插件 flutter-bubble-tab-indicator A Flutter librar ......

    uj5u.com 2020-09-10 06:58:52 more
  • Proguard 常用規則

    介紹 Proguard 入口,如何查看輸出,如何使用 keep 設定入口以及使用實體,如何配置壓縮,混淆,校驗等規則。

    ......

    uj5u.com 2020-09-10 06:59:00 more
  • Android 開發技術周報 Issue#292

    新聞 Android即將獲得類AirDrop功能:可向附近設備快速分享檔案 谷歌為安卓檔案管理應用引入可安全隱藏資料的Safe Folder功能 Android TV新主界面將顯示電影、電視節目和應用推薦內容 泄露的Android檔案暗示了傳說中的谷歌Pixel 5a與折疊屏新機 谷歌發布Andro ......

    uj5u.com 2020-09-10 07:00:37 more
  • AutoFitTextureView Error inflating class

    報錯: Binary XML file line #0: Binary XML file line #0: Error inflating class xxx.AutoFitTextureView 解決: <com.example.testy2.AutoFitTextureView android: ......

    uj5u.com 2020-09-10 07:00:41 more
  • 根據Uri,Cursor沒有獲取到對應的屬性

    Android: 背景:呼叫攝像頭,拍攝視頻,指定保存的地址,但是回傳的Cursor檔案,只有名稱和大小的屬性,沒有其他諸如時長,連ID屬性都沒有 使用 cursor.getInt(cursor.getColumnIndexOrThrow(MediaStore.Video.Media.DURATIO ......

    uj5u.com 2020-09-10 07:00:44 more
  • Android連載29-持久化技術

    一、持久化技術 我們平時所使用的APP產生的資料,在記憶體中都是瞬時的,會隨著斷電、關機等丟失資料,因此android系統采用了持久化技術,用于存盤這些“瞬時”資料 持久化技術包括:檔案存盤、SharedPreference存盤以及資料庫存盤,還有更復雜的SD卡記憶體儲。 二、檔案存盤 最基本存盤方式, ......

    uj5u.com 2020-09-10 07:00:47 more
  • Android Camera2Video整合到自己專案里

    背景: Android專案里呼叫攝像頭拍攝視頻,原本使用的 MediaStore.ACTION_VIDEO_CAPTURE, 后來因專案需要,改成了camera2 1.Camera2Video 官方demo有點問題,下載后,不能直接整合到專案 問題1.多次拍攝視頻崩潰 問題2.雙擊record按鈕, ......

    uj5u.com 2020-09-10 07:00:50 more
  • Android 開發技術周報 Issue#293

    新聞 谷歌為Android TV開發者提供多種新功能 Android 11將自動填表功能整合到鍵盤輸入建議中 谷歌宣布Android Auto即將支持更多的導航和數字停車應用 谷歌Pixel 5只有XL版本 搭載驍龍765G且將比Pixel 4更便宜 [圖]Wear OS將迎來重磅更新:應用啟動時間 ......

    uj5u.com 2020-09-10 07:01:38 more
  • 海豚星空掃碼投屏 Android 接收端 SDK 集成 六步驟

    掃碼投屏,開放網路,獨占設備,不需要額外下載軟體,微信掃碼,發現設備。支持標準DLNA協議,支持倍速播放。視頻,音頻,圖片投屏。好點意思。還支持自定義基于 DLNA 擴展的操作動作。好像要收費,沒體驗。 這里簡單記錄一下集成程序。 一 跟目錄的build.gradle添加私有mevan倉庫 mave ......

    uj5u.com 2020-09-10 07:01:43 more
最新发布
  • 歡迎頁輪播影片

    如圖,引導開始,球從上落下,同時淡入文字,然后文字開始輪播,最后一頁時停止,點擊進入首頁。 在來看看效果圖。 重力球先不講,主要歡迎輪播簡單實作 首先新建一個類 TextTranslationXGuideView,用于影片展示 文本是類似的,最后會有個圖片箭頭影片,布局很簡單,就是一個 TextVi ......

    uj5u.com 2023-04-20 08:40:31 more
  • 【FAQ】關于華為推送服務因營銷訊息頻次管控導致服務通訊類訊息

    一. 問題描述 使用華為推送服務下發IM訊息時,下發訊息請求成功且code碼為80000000,但是手機總是收不到訊息; 在華為推送自助分析(Beta)平臺查看發現,訊息發送觸發了頻控。 二. 問題原因及背景 2023年1月05日起,華為推送服務對咨詢營銷類訊息做了單個設備每日推送數量上限管理,具體 ......

    uj5u.com 2023-04-20 08:40:11 more
  • 歡迎頁輪播影片

    如圖,引導開始,球從上落下,同時淡入文字,然后文字開始輪播,最后一頁時停止,點擊進入首頁。 在來看看效果圖。 重力球先不講,主要歡迎輪播簡單實作 首先新建一個類 TextTranslationXGuideView,用于影片展示 文本是類似的,最后會有個圖片箭頭影片,布局很簡單,就是一個 TextVi ......

    uj5u.com 2023-04-20 08:39:36 more
  • 【FAQ】關于華為推送服務因營銷訊息頻次管控導致服務通訊類訊息

    一. 問題描述 使用華為推送服務下發IM訊息時,下發訊息請求成功且code碼為80000000,但是手機總是收不到訊息; 在華為推送自助分析(Beta)平臺查看發現,訊息發送觸發了頻控。 二. 問題原因及背景 2023年1月05日起,華為推送服務對咨詢營銷類訊息做了單個設備每日推送數量上限管理,具體 ......

    uj5u.com 2023-04-20 08:39:13 more
  • iOS從UI記憶體地址到讀取成員變數(oc/swift)

    開發除錯時,我們發現bug時常首先是從UI顯示發現例外,下一步才會去定位UI相關連的資料的。XCode有給我們提供一系列debug工具,但是很多人可能還沒有形成一套穩定的除錯流程,因此本文嘗試解決這個問題,順便提出一個暴論:UI顯示例外問題只需要兩個步驟就能完成定位作業的80%: 定位例外 UI 組 ......

    uj5u.com 2023-04-19 09:16:23 more
  • FIDE重磅更新!性能飛躍!體驗有禮!

    FIDE 開發者工具重構升級啦!實作500%性能提升,誠邀體驗! 一直以來不少開發者朋友在社區反饋,在使用 FIDE 工具的程序中,時常會遇到諸如加載不及時、代碼預覽/渲染性能不如意的情況,十分影響開發體驗。 作為技術團隊,我們深知一件趁手的開發工具對開發者的重要性,因此,在2023年開年,FinC ......

    uj5u.com 2023-04-19 09:16:15 more
  • 游戲內嵌社區服務開放,助力開發者提升玩家互動與留存

    華為 HMS Core 游戲內嵌社區服務提供快速訪問華為游戲中心論壇能力,支持玩家直接在游戲內瀏覽帖子和交流互動,助力開發者擴展內容生產和觸達的場景。 一、為什么要游戲內嵌社區? 二、游戲內嵌社區的典型使用場景 1、游戲內打開論壇 您可以在游戲內繪制論壇入口,為玩家提供沉浸式發帖、瀏覽、點贊、回帖、 ......

    uj5u.com 2023-04-19 09:15:46 more
  • iOS從UI記憶體地址到讀取成員變數(oc/swift)

    開發除錯時,我們發現bug時常首先是從UI顯示發現例外,下一步才會去定位UI相關連的資料的。XCode有給我們提供一系列debug工具,但是很多人可能還沒有形成一套穩定的除錯流程,因此本文嘗試解決這個問題,順便提出一個暴論:UI顯示例外問題只需要兩個步驟就能完成定位作業的80%: 定位例外 UI 組 ......

    uj5u.com 2023-04-19 09:14:53 more
  • FIDE重磅更新!性能飛躍!體驗有禮!

    FIDE 開發者工具重構升級啦!實作500%性能提升,誠邀體驗! 一直以來不少開發者朋友在社區反饋,在使用 FIDE 工具的程序中,時常會遇到諸如加載不及時、代碼預覽/渲染性能不如意的情況,十分影響開發體驗。 作為技術團隊,我們深知一件趁手的開發工具對開發者的重要性,因此,在2023年開年,FinC ......

    uj5u.com 2023-04-19 09:14:08 more
  • 游戲內嵌社區服務開放,助力開發者提升玩家互動與留存

    華為 HMS Core 游戲內嵌社區服務提供快速訪問華為游戲中心論壇能力,支持玩家直接在游戲內瀏覽帖子和交流互動,助力開發者擴展內容生產和觸達的場景。 一、為什么要游戲內嵌社區? 二、游戲內嵌社區的典型使用場景 1、游戲內打開論壇 您可以在游戲內繪制論壇入口,為玩家提供沉浸式發帖、瀏覽、點贊、回帖、 ......

    uj5u.com 2023-04-19 09:08:34 more