Vue3中如何使用異步請求示例詳解
1、前言
接上節(jié),我們初步體驗了layui-vue的用法。相比其他ui框架,layui-vue的數(shù)據(jù)結(jié)構(gòu)顯得不是非常友好,但是經(jīng)過數(shù)據(jù)拼湊也是能夠成功運行的。
今天我們就主要介紹下在實際開發(fā)中最常用到的前后端接口交互。因為大多數(shù)時候前端為了高性能,對于后端接口的調(diào)用都會采用異步的方式。那該如何在vue3中使用異步請求渲染頁面呢?
2、快速開始
2.1、思路
預(yù)期:前端急速響應(yīng)、初始數(shù)據(jù)為空,異步接口響應(yīng)后對頁面數(shù)據(jù)表格進行響應(yīng)式更新。
我們都知道vue的核心特性就是響應(yīng)式,為了能夠?qū)崿F(xiàn)我們預(yù)期的效果,我們需要進行以下幾步。
- 首先安裝axios
- 封裝axios
- 設(shè)計接口
- 在vue視圖中將表格數(shù)據(jù)變量聲明為響應(yīng)式。初始化空值。
- 在vue視圖中異步調(diào)用接口
- 將從后端獲取到的數(shù)據(jù)push到響應(yīng)式變量中。
2.2、安裝&封裝axios
安裝axios
npm i axios --save
封裝axios
在src
下新建request/svc.js
,并對axios進行封裝
import axios from 'axios' ? // 設(shè)置超時時間 axios.defaults.timeout = 5000 ? // 創(chuàng)建axios實例 const service = axios.create({ baseURL: 'http://localhost:8000', // 所有的請求地址前綴部分 timeout: 60000, // 請求超時時間毫秒 withCredentials: true, // 異步請求攜帶cookie headers: { // 設(shè)置后端需要的傳參類型 'Content-Type': 'application/json', 'token': 'your token', // 'X-Requested-With': 'XMLHttpRequest', }, }) ? // 導(dǎo)出 export default service
如上,我們對axios進行簡單的封裝,已經(jīng)能夠?qū)崿F(xiàn)統(tǒng)一URL、超時時間和請求頭。
關(guān)于請求攔截等后續(xù)再進行講解。
2.3、設(shè)計接口
首先在src
下新建apis/bugs.js
文件,然后設(shè)計一個方法(接口)去調(diào)用后端接口。
// 導(dǎo)入axios實例 import httpRequest from '@/request/svc' ? // 獲取BUG信息 export function apiGetBugs() { return httpRequest({ url: 'bug3', method: 'get', params: {'dd': 'xxx'}, }) }
如上,我們在接口文件中調(diào)用封裝的axios實例對后端的接口發(fā)起請求,并將請求相應(yīng)對象返回。
2.4、設(shè)計視圖
有了上面的基礎(chǔ),我們可以在vue的視圖中直接導(dǎo)入bugs.js中的接口,然后在實例的onMounted階段去異步調(diào)用接口,當(dāng)接口返回后再去更新頁面。
<template> <!-- 上節(jié)的內(nèi)容 --> <lay-button type="primary">原始按鈕</lay-button> <lay-button>默認(rèn)按鈕</lay-button> <lay-button type="normal">百搭按鈕</lay-button> <lay-button type="warm">暖色按鈕</lay-button> <lay-button type="danger">警告按鈕</lay-button> <hr> <!-- 本節(jié)內(nèi)容 --> <lay-table :columns="columns1" :dataSource="dataSource1"></lay-table> </template> ? <script> // 本節(jié)內(nèi)容 import { onMounted,reactive } from 'vue' import { apiGetBugs } from '@/apis/bugs' ? export default { setup() { console.log('do something...') // 聲明表格數(shù)據(jù)變量未聲明式 let dataSource1=reactive([]) // 掛載階段異步調(diào)用接口 onMounted(async()=>{ let res = await apiGetBugs() const ret = res.data console.log(ret) // 將接口返回的數(shù)據(jù)push到響應(yīng)式變量中 dataSource1.push(...[{close:ret[0][0],fixing:ret[0][1],refused:ret[0][2],fixed:ret[0][3],reopen:ret[0][4]},]) }) // 表頭 const columns1 = [ { title:"關(guān)閉", width:"200px", key:"close" }, { title:"修復(fù)中", width:"200px", key:"fixing" }, { title:"拒絕", width:"200px", key:"refused" }, { title:"已修復(fù)", width:"200px", key:"fixed" }, { title:"重新打開", width:"200px", key:"reopen", ellipsisTooltip: true } ] // 完整的layui-vue的表格數(shù)據(jù)結(jié)構(gòu) return { columns1, dataSource1 } } } ? </script>? <style> </style>
2.5、最終效果
以上,我們就完成了vue3的異步請求后端并完成頁面渲染。
總結(jié)
到此這篇關(guān)于Vue3中如何使用異步請求的文章就介紹到這了,更多相關(guān)Vue3使用異步請求內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue3 Ref獲取真實DOM學(xué)習(xí)實戰(zhàn)
這篇文章主要為大家介紹了Vue3 Ref獲取真實DOM學(xué)習(xí)實戰(zhàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-06-06vue.js中使用echarts實現(xiàn)數(shù)據(jù)動態(tài)刷新功能
這篇文章主要介紹了vue.js中使用echarts實現(xiàn)數(shù)據(jù)動態(tài)刷新功能,需要的朋友可以參考下2019-04-04Vue3+TypeScript+Vite使用require動態(tài)引入圖片等靜態(tài)資源
本文主要介紹了Vue3+TypeScript+Vite使用require動態(tài)引入圖片等靜態(tài)資源,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07antd vue 如何調(diào)整checkbox默認(rèn)樣式
這篇文章主要介紹了antd vue 如何調(diào)整checkbox默認(rèn)樣式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-12-12vue項目接口管理,所有接口都在apis文件夾中統(tǒng)一管理操作
這篇文章主要介紹了vue項目接口管理,所有接口都在apis文件夾中統(tǒng)一管理操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-08-08