Vue3如何使用axios發(fā)起網(wǎng)絡(luò)請求
Vue3使用axios發(fā)起網(wǎng)絡(luò)請求
即使是小型項(xiàng)目也會涉及到請求后端API,除非你的網(wǎng)站展示的是一些不需要維護(hù)的靜態(tài)數(shù)據(jù),第三篇文章我們來給Vue項(xiàng)目搞上axios。
1.何為Axios?
請看官方對Axios的描述,傳送門:官方文檔
Axios 是一個(gè)基于 promise 網(wǎng)絡(luò)請求庫,作用于node.js 和瀏覽器中。 它是 isomorphic 的(即同一套代碼可以運(yùn)行在瀏覽器和node.js中)。在服務(wù)端它使用原生 node.js http 模塊, 而在客戶端 (瀏覽端) 則使用 XMLHttpRequests。
2.如何安裝Axios
這部分我使用了幾個(gè)不同版本的node都沒有報(bào)錯(cuò),兼容性還是不錯(cuò)的。
yarn add axios?
3.如何封裝網(wǎng)絡(luò)請求和全局實(shí)例化axios
官網(wǎng)的實(shí)例都是在單個(gè)文件中局部實(shí)例化axios,在項(xiàng)目上使用不多。
按照之前的文章操作成功后,還需要在你的項(xiàng)目src目錄下新建api文件夾

4. api.js是什么?
這里面封裝了所有的API請求,可以指定是否有參數(shù),指定請求的類型是GET、POST、DELETE還是PUT
import http from './http.js'
// 獲取驗(yàn)證碼,這個(gè)函數(shù)指的是使用GET請求請求目標(biāo)服務(wù)器的
Captcha路由
export function getCaptcha() {
return http.get("/captcha")
}
// 驗(yàn)證用戶名\密碼,這里指的是使用POST方法請求Login接口,并攜帶params對象作為參數(shù)。
export function verifyUserNameAPI(params) {
return http.post("/login", params)
}5.http.js是什么?
import request from '@/api/request'
const http = {
get(url, params) {
const config = {
method: 'get',
url: url
} /*這里如果GET請求有參數(shù),則攜帶上傳入的參數(shù),在
URL中以?的方式放在請求鏈接中*/
if (params) config.params = params
return request(config)
},
post(url, params) {
const config = {
method: 'post',
url: url
}/*同理也是傳入用戶需要發(fā)送到后臺的參數(shù),這些參數(shù)
放在報(bào)文中,載體表達(dá)標(biāo)準(zhǔn)是JSON*/
if (params) config.data = params
return request(config)
},
}
//暴露接口,允許Vue文件或其他js,ts文件使用http結(jié)構(gòu)體中的方法
export default http6.request.js是什么?
這個(gè)是核心的JS文件,表明了后端的地址,接口超時(shí)時(shí)間,以及請求攔截器和響應(yīng)攔截器部分。
import axios from 'axios';
// 創(chuàng)建一個(gè)自定義的Axios對象
const Axios = axios.create({
baseURL: 'http://127.0.0.1:1234',
timeout: 3000,
/*也可以不設(shè)置Content-Type,影響是在你發(fā)送請求時(shí)
Vue會先發(fā)送OPTIONS包探測路由是否存在,需要后端也做設(shè)置響應(yīng)OPTIONS
方法,否則會報(bào)跨域錯(cuò)誤;我這里用的Beego2,路由里不響應(yīng)OPTIONS方法,
所以我在這塊設(shè)置Content-Type*/
headers: {
'Content-Type': 'application/x-www-form-urlencoded'
},
/*這個(gè)配置很重要,允許axios攜帶用戶Cookie到后端,不設(shè)置這個(gè)的話
Set-Cookie是無效的,除此之外,Chrome默認(rèn)開啟了SameSite檢查,如果
后端不主動(dòng)設(shè)置SameSite = none,Set-Cookie是無效的。詳情請文章末尾
參考阮老師的SameSite講解*/
withCredentials: true
});
Axios.interceptors.request.use(req => {
// 請求攔截處理
// console.log('這里是請求攔截器,我攔截了請求', req);
return req;
}, err => {
console.log('在發(fā)送請求時(shí)發(fā)生錯(cuò)誤,錯(cuò)誤為', err);
//這里不能直接放回err,需要按照官方說明返回一個(gè)Promise
return Promise.reject(err);
})
Axios.interceptors.response.use(res => {
// 響應(yīng)攔截處理
// console.log('響應(yīng)攔截 ', res);
return res.data;
}, error => {
const err = error.toString();
//按照實(shí)際的響應(yīng)包進(jìn)行解析,通過關(guān)鍵字匹配的方式
switch (true) {
case err.indexOf('Network') !== -1:
console.log('后端服務(wù)器無響應(yīng)或者URL錯(cuò)誤', err);
break;
case err.indexOf('timeout') !== -1:
console.log('請求后端服務(wù)器超時(shí)!', err);
break;
}
return Promise.reject(error);
})
//暴露Axios實(shí)例化對象,允許所有文件調(diào)用Axios
export default Axios;
7.如何在Vue文件中請求封裝好的API呢?
//導(dǎo)入聲明的API請求函數(shù)
import { getCaptcha } from "@/api/api";
import { useMessage } from "naive-ui";
export default {
setup() {
let captchaId = ref();
onMounted(() => {
//onMounted是Vue聲明周期的鉤子函數(shù),由Vue提供,
//請參考Vue聲明周期鉤子官方文檔
getcaptchaAPI();
});
function getcaptchaAPI() {
getCaptcha()
.then((res) => {
/*這里的res是響應(yīng)成功是返回的數(shù)據(jù),res.data說明獲取報(bào)文
中的data字段對應(yīng)的值,我在setup聲明使用的ref,所以賦值時(shí)
需要使用captchaId.value的方式*/
captchaId.value = res.data;
})
//在這里處理錯(cuò)誤
.catch((err) => console.log(err));
}
}
}就到這里了,現(xiàn)在你的項(xiàng)目既能請求后端接口,又能進(jìn)行路由跳轉(zhuǎn),具備了項(xiàng)目的基本條件,可以嘗試寫一個(gè)簡單地頁面了。
Vue3.0請求接口的例子
<script>
// getInTheaters 為封裝的接口請求
import { getInTheaters } from "@/api/movie";
import {
reactive,
toRefs,
onBeforeMount,
onMounted,
onBeforeUnmount,
provide,
} from "vue";
import { useRouter } from "vue-router";
import { useStore } from 'vuex'
export default {
components: {},
setup() {
const state = reactive({
inTheaters: [],
});
// 編程式導(dǎo)航
const router = useRouter();
const store = useStore();
onBeforeMount(() => {
store.commit("setShowBack", false);
});
onBeforeUnmount(() => {
store.commit("setShowBack", true);
});
const getInTheatersData = async () => {
const res = await getInTheaters(
"/gateway?cityId=310100&pageNum=1&pageSize=10&type=1&k=3535827"
);
state.inTheaters = res.data.data.films;
onMounted(() => {
//執(zhí)行請求
getInTheatersData();
});
//頁面跳轉(zhuǎn)
const goToList = (type) => {
router.push(`/list/${type}`);
};
// 傳遞數(shù)據(jù)給子組件
provide("title", "電影");
return { ...toRefs(state), goToList };
};
},
};
</script>以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue中el-tree結(jié)合el-switch實(shí)現(xiàn)開關(guān)狀態(tài)切換
本文主要介紹了vue中el-tree結(jié)合el-switch實(shí)現(xiàn)開關(guān)狀態(tài)切換,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-12-12
Vue如何實(shí)現(xiàn)監(jiān)聽組件原生事件
這篇文章主要介紹了Vue如何實(shí)現(xiàn)監(jiān)聽組件原生事件,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07
Vue全局監(jiān)測錯(cuò)誤并生成錯(cuò)誤日志實(shí)現(xiàn)方法介紹
在做完一個(gè)項(xiàng)目后,之后的維護(hù)尤為重要。這時(shí),如果項(xiàng)目配置了錯(cuò)誤日志記錄,這樣能大大減少維護(hù)難度。雖然不一定能捕獲到全部的錯(cuò)誤,但是一般的錯(cuò)誤還是可以監(jiān)測到的。這樣就不用測試人員去一遍一遍復(fù)現(xiàn)bug了2022-10-10

