使用Vue3和Axios進(jìn)行API數(shù)據(jù)交互的代碼實(shí)現(xiàn)
引言
在現(xiàn)代Web開發(fā)中,前端框架和庫的使用越來越普遍,Vue.js便是其中一個(gè)受歡迎的選擇。通過Vue 3引入的Composition API和setup語法糖,我們可以更靈活地組織代碼,并提高代碼的可讀性和可維護(hù)性。與此同時(shí),Axios作為一個(gè)基于Promise的HTTP客戶端,能夠幫助我們輕松地與API進(jìn)行交互。在這篇博客中,我將介紹如何利用Vue 3及Axios進(jìn)行API數(shù)據(jù)交互,并通過示例代碼來展示其基本用法。
1. 環(huán)境準(zhǔn)備
在開始之前,請(qǐng)確保你已經(jīng)裝好了Node.js和npm。接下來,我們可以使用Vue CLI來創(chuàng)建一個(gè)新項(xiàng)目。打開終端,執(zhí)行以下命令:
npm install -g @vue/cli vue create vue-axios-example cd vue-axios-example npm install axios
此時(shí),我們已經(jīng)創(chuàng)建了一個(gè)新的Vue項(xiàng)目并安裝了Axios模塊。
2. 組件結(jié)構(gòu)
在這個(gè)示例中,我們將創(chuàng)建一個(gè)簡單的組件,該組件將從一個(gè)公共API(例如JSONPlaceholder)獲取一些數(shù)據(jù)并顯示在頁面上。我們將在src/components目錄下創(chuàng)建一個(gè)新的文件UserList.vue。
<template>
<div>
<h1>User List</h1>
<ul v-if="users.length">
<li v-for="user in users" :key="user.id">
{{ user.name }} - {{ user.email }}
</li>
</ul>
<p v-else>Loading users...</p>
<button @click="fetchUsers">Refresh Users</button>
</div>
</template>
<script>
import { ref } from 'vue';
import axios from 'axios';
export default {
name: 'UserList',
setup() {
const users = ref([]);
const fetchUsers = async () => {
try {
const response = await axios.get('https://jsonplaceholder.typicode.com/users');
users.value = response.data;
} catch (error) {
console.error('Error fetching users:', error);
}
};
// On component mount, fetch users
fetchUsers();
return {
users,
fetchUsers
};
},
};
</script>
<style scoped>
h1 {
color: #42b983;
}
</style>
2.1 組件分析
顯示從API獲取到的用戶數(shù)據(jù)。如果數(shù)據(jù)還在加載中,會(huì)顯示“Loading users…”提示。
腳本部分:在
<script>部分,我們使用setup函數(shù)。在這個(gè)函數(shù)中,我們使用ref來創(chuàng)建一個(gè)響應(yīng)式變量users,并定義異步函數(shù)fetchUsers來獲取用戶數(shù)據(jù)。fetchUsers函數(shù)使用Axios發(fā)送GET請(qǐng)求,獲取JSONPlaceholder的用戶數(shù)據(jù)。users.value = response.data將獲取到的數(shù)據(jù)賦值給users。
樣式部分:
<style scoped>確保樣式只作用于當(dāng)前組件。
3. 使用組件
為了在應(yīng)用中使用我們的組件,我們可以在src/App.vue中進(jìn)行如下修改:
<template>
<div id="app">
<UserList />
</div>
</template>
<script>
import UserList from './components/UserList.vue';
export default {
name: 'App',
components: {
UserList,
},
};
</script>
<style>
#app {
text-align: center;
margin-top: 60px;
}
</style>
在這里,我們首先導(dǎo)入UserList組件,然后在模板中使用它。這樣,我們就可以在主應(yīng)用程序中看到用戶列表。
4. 運(yùn)行項(xiàng)目
到此為止,我們的項(xiàng)目已經(jīng)準(zhǔn)備完成?,F(xiàn)在,我們可以運(yùn)行開發(fā)服務(wù)器,查看我們的組件效果:
npm run serve
打開瀏覽器,訪問http://localhost:8080,你將看到一個(gè)用戶列表,且下方有一個(gè)“Refresh Users”按鈕,點(diǎn)擊此按鈕可以重新獲取用戶數(shù)據(jù)。
5. 異常處理
在上面的fetchUsers函數(shù)中,我們已經(jīng)涉及到了簡單的錯(cuò)誤處理。如果在請(qǐng)求過程中出現(xiàn)任何錯(cuò)誤,開發(fā)者將會(huì)看到控制臺(tái)輸出相關(guān)錯(cuò)誤信息。為了進(jìn)一步提升用戶體驗(yàn),我們可以在UI中增加一些錯(cuò)誤提示。
修改UserList.vue中的狀態(tài)管理:
<template>
<div>
<h1>User List</h1>
<ul v-if="users.length">
<li v-for="user in users" :key="user.id">
{{ user.name }} - {{ user.email }}
</li>
</ul>
<p v-else-if="error">{{ error }}</p>
<p v-else>Loading users...</p>
<button @click="fetchUsers">Refresh Users</button>
</div>
</template>
<script>
import { ref } from 'vue';
import axios from 'axios';
export default {
name: 'UserList',
setup() {
const users = ref([]);
const error = ref(null);
const fetchUsers = async () => {
error.value = null; // 清空錯(cuò)誤
try {
const response = await axios.get('https://jsonplaceholder.typicode.com/users');
users.value = response.data;
} catch (err) {
error.value = 'Error fetching users: ' + err.message;
}
};
fetchUsers();
return { users, fetchUsers, error };
},
};
</script>
在這段代碼中,我們引入了一個(gè)新的響應(yīng)式變量error,用于保存錯(cuò)誤信息,并在UI中進(jìn)行適當(dāng)?shù)娘@示。這樣,用戶在獲取數(shù)據(jù)失敗時(shí),可以看到相關(guān)的錯(cuò)誤提示。
總結(jié)
通過本篇博客,我們學(xué)習(xí)了如何使用Vue 3的setup語法糖以及Axios進(jìn)行簡單的API數(shù)據(jù)交互。借助這些現(xiàn)代化的工具,我們可以更加靈活地管理前端狀態(tài)與API請(qǐng)求。無論是創(chuàng)建獨(dú)立的組件還是構(gòu)建復(fù)雜的應(yīng)用,這種方法都能大大提高我們的開發(fā)效率與代碼質(zhì)量。
以上就是使用Vue3和Axios進(jìn)行API數(shù)據(jù)交互的代碼實(shí)現(xiàn)的詳細(xì)內(nèi)容,更多關(guān)于Vue3 Axios API數(shù)據(jù)交互的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
如何用VUE和Canvas實(shí)現(xiàn)雷霆戰(zhàn)機(jī)打字類小游戲
這篇文章主要介紹了如何用VUE和Canvas實(shí)現(xiàn)雷霆戰(zhàn)機(jī)打字類小游戲,麻雀雖小,五臟俱全,對(duì)游戲感興趣的同學(xué),可以參考下,研究里面的原理和實(shí)現(xiàn)方法2021-04-04
詳解如何在vue項(xiàng)目中使用eslint+prettier格式化代碼
在開發(fā)中我們需要一種能夠統(tǒng)一團(tuán)隊(duì)代碼風(fēng)格的工具,作為強(qiáng)制性的規(guī)范,統(tǒng)一整個(gè)項(xiàng)目的代碼風(fēng)格,這篇文章主要介紹了詳解如何在vue項(xiàng)目中使用eslint+prettier格式化代碼,需要的朋友可以參考下2018-11-11
vue計(jì)算屬性+vue中class與style綁定(推薦)
這篇文章主要介紹了vue計(jì)算屬性+vue中class與style綁定,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-03-03
vue獲取當(dāng)前日期時(shí)間(使用moment和new?Date())
在項(xiàng)目開發(fā)中我遇到了日期范圍選擇器,兩種獲取當(dāng)前日期并做處理的寫法,這里記錄一下,下面這篇文章主要給大家介紹了關(guān)于vue獲取當(dāng)前日期時(shí)間(使用moment和new?Date())的相關(guān)資料,需要的朋友可以參考下2023-06-06
基于vue實(shí)現(xiàn)一個(gè)神奇的動(dòng)態(tài)按鈕效果
今天我們將利用vue的條件指令來完成一個(gè)簡易的動(dòng)態(tài)變色功能按鈕,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2019-05-05
vue實(shí)現(xiàn)短信驗(yàn)證碼登錄功能(流程詳解)
無論是移動(dòng)端還是pc端登錄或者注冊(cè)界面都會(huì)見到手機(jī)驗(yàn)證碼登錄這個(gè)功能,輸入手機(jī)號(hào),得到驗(yàn)證碼,這篇文章主要介紹了基于vue實(shí)現(xiàn)短信驗(yàn)證碼登錄功能,需要的朋友可以參考下2019-12-12

