一文詳解vue3項目實戰(zhàn)中的接口調(diào)用
前言
在企業(yè)開發(fā)過程中,有著明確的前后端分工,前端負責(zé)接收、使用接口,后端負責(zé)編寫、處理接口。本期文章將會詳細講解 如何使用接口。
vue項目組成
一個項目往往由這幾個部分組成。????

其中在src文件夾中的內(nèi)容如下????

我們常常將接口文件,新建在文件夾src下,一般命名為api,api內(nèi)的文件便是接口文件。????

接口調(diào)用具體內(nèi)容
通常把后端的接口寫在api文件夾下,命名采用駝峰命名法,比如loginApi、orderApi、countApi等等。
loginApi.ts內(nèi)容

源碼:
import { userType } from '../types/login'
import request from '../utils/request'
// 定義并導(dǎo)出請求接口函數(shù)userLoginApi 參數(shù)值為loginform 參數(shù)類型為userType
export function userLoginApi(loginform: userType) {
return request({ // 返回request請求
url: '/api/v1/user/member/private/login', // 請求接口的地址
method: 'post', // 請求方式是post 還有g(shù)et等方法(了解)
data: loginform // 請求的數(shù)據(jù)是loginform 在驗證請求的時候可能請求的值為value
})
}
request.ts內(nèi)容
(axios請求需要安裝 /store為跨域處理) 后期文章將進行補充講解

源碼:
// 引入axios封裝
import axios from 'axios'
import { message } from 'ant-design-vue'
// 創(chuàng)建axios實例
const request = axios.create({
baseURL: '/store', // url = base url + request url
timeout: 5000 // 5s超時
})
// 請求攔截器 一般寫法模式
request.interceptors.request.use(
(response) => {
return response // 請求成功則返回response
},
(error) => { // 請求失敗則顯示錯誤狀態(tài)
message.error(error.message)
return Promise.reject(error)
}
)
// 響應(yīng)攔截器
request.interceptors.response.use(
(response) => {
return response
},
(error) => {
message.error(error.message)
return Promise.reject(error)
}
)
// 導(dǎo)出request
export default request
vite.config.ts文件:

項目的頁面往往寫在view中,每個頁面設(shè)一個文件夾,其中xxx.vue內(nèi)容則是本頁面的內(nèi)容。

在頁面中,如果我們需要使用某個接口。則需要進行引入操作。
import {接口名1、接口名2} from ' api文件地址 '
// from后所跟的就是api中文件的地址路徑
import { userLoginApi } from '../api/loginApi';
接口往往是在方法中進行調(diào)用,對于不同接口 ,需要的參數(shù)也不一樣,根據(jù)需求,我們傳入對應(yīng)的參數(shù)即可。
接口的使用格式:
調(diào)用接口有三種方式:
fetchasync/awaitaxios后期文章持續(xù)更新 詳細講解
fetch方法:
接口名({參數(shù)1:頁面中的參1,參數(shù)2:頁面中的參數(shù)2}).then(res => {
console.log(res)
//res就是調(diào)用接口后,后臺返回過來的結(jié)果,一般數(shù)據(jù)儲存在res.data.data中,具體情況而論
})
async await方法:

const handleFinish = async (value: any) => { // 表單輸入完畢后點登錄調(diào)用handleFinish函數(shù)
// async包裹handleFinish函數(shù)的參數(shù)value 傳參
console.log(value)
const {data:res} = await userLoginApi(value) // 對data解構(gòu)賦值 取出請求結(jié)果res data是請求接口中存放表單數(shù)據(jù)的變量
// 先從請求接口的函數(shù)userLoginApi中獲取存入的表單數(shù)據(jù)value 然后用await包裹 賦值給請求結(jié)果res
console.log(res)
}
以上就是接口調(diào)用的全部過程了??梢栽诎?strong>F12打開控制臺查看調(diào)用結(jié)果。

總結(jié)
到此這篇關(guān)于vue3項目實戰(zhàn)中的接口調(diào)用的文章就介紹到這了,更多相關(guān)vue3項目接口調(diào)用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
el-input輸入校驗不能為空格以及不能輸入全部為空的內(nèi)容
這篇文章主要給大家介紹了關(guān)于el-input輸入校驗不能為空格以及不能輸入全部為空的內(nèi)容的相關(guān)資料,el-input驗證規(guī)則主要是為了確保輸入的內(nèi)容符合特定的要求,需要的朋友可以參考下2023-10-10
vue實現(xiàn)多組關(guān)鍵詞對應(yīng)高亮顯示功能
最近小編遇到這樣的問題,多組關(guān)鍵詞,這里實現(xiàn)了關(guān)鍵詞的背景色與匹配值的字體顏色值相同,下面通過定義關(guān)鍵詞匹配改變字體顏色,本文通過實例代碼給大家介紹的非常詳細,需要的朋友參考下吧2019-07-07
安裝vue3開發(fā)者工具但控制臺沒有顯示出vue選項的解決
這篇文章主要介紹了安裝vue3開發(fā)者工具但控制臺沒有顯示出vue選項的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10
關(guān)于Vue中echarts響應(yīng)式頁面變化resize()的用法介紹
Vue項目中開發(fā)數(shù)據(jù)大屏,使用echarts圖表根據(jù)不同尺寸的屏幕進行適配,resize()可以調(diào)用echarts中內(nèi)置的resize函數(shù)進行自適應(yīng)縮放,本文將給大家詳細介紹resize()的用法,需要的朋友可以參考下2023-06-06
關(guān)于下拉類型多選組件Vue-Treeselect(鍵名轉(zhuǎn)換)
這篇文章主要介紹了關(guān)于下拉類型多選組件Vue-Treeselect(鍵名轉(zhuǎn)換),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07
Vue3?使用v-model實現(xiàn)父子組件通信的方法(常用在組件封裝規(guī)范中)
這篇文章主要介紹了Vue3?使用v-model實現(xiàn)父子組件通信(常用在組件封裝規(guī)范中)的方法,本文通過實例代碼給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧2024-06-06

