Vue?3.0?中?hooks?的概念示例詳解
背景:在一些情況下,前臺的組件是可以復(fù)用的,那這些復(fù)用的對象和數(shù)據(jù),為了避免直接寫在一個vue文件中的混亂性,我們可以為每一個類型的內(nèi)容,寫成一個hooks,以便后面重復(fù)利用
一、示例

App.vue
<template>
<Person/>
</template>
<script lang="ts" setup name="App"> //當前根組件的組件名
import Person from './components/Person.vue'
</script>
<style >
.app {
background-color: #ddd;
box-shadow: 0 0 10px;
border-radius: 10px;
padding: 20px;
}
</style>
**useSum.ts**
```html
import {ref,reactive, computed} from 'vue'
import axios from 'axios'
export default function(){
let sum =ref(0);
let bigSum =computed(()=>{
return sum.value*10;
})
function addSum(){
sum.value+=1;
}
return {sum,addSum,bigSum}
}useDog.ts
import {ref,reactive} from 'vue'
import axios from 'axios'
export default function(){
let dogList = reactive([
'https://images.dog.ceo//breeds//pembroke//n02113023_11091.jpg'
]);
async function getDog(){
try{
let result = await axios.get('https://dog.ceo/api/breed/pembroke/images/random');
dogList.push(result.data.message)
}catch(error){
alert(error);
}
}
return {dogList,getDog};
}Person.vue,在此vue中使用上面的兩個組件;
<template>
<div class="person">
<h2>求和:{{sum}}====bigSum:{{bigSum}}</h2>
<button @click="addSum">和加一</button>
<hr/>
<img v-for="(dog,index) in dogList" :key="index" :src="dog"><br/>
<button @click="getDog"> 點我換小狗</button>
</div>
</template>
<script lang="ts" setup name="Person">
import useDog from '@/hooks/useDog';
import useSum from '@/hooks/useSum';
let {dogList,getDog} = useDog();
let {sum,addSum,bigSum} = useSum();
</script>
<style scoped>
.person {
background-color: skyblue;
box-shadow: 0 0 10px;
border-radius: 10px;
padding: 20px;
}
li {
font: 1em sans-serif;
}
img {
height: 100px;
margin-right: 10px;
}
</style>展示效果

在這個例子中,很好地展示了 Vue 3.0 中 hooks 的概念及使用方式。
二、Vue 3.0 中 hooks 的概念
Hooks 是一組以 use 開頭的函數(shù),用于在 Vue 3 的函數(shù)式組件(使用 setup 函數(shù)的組件)中封裝和復(fù)用有狀態(tài)的邏輯。它們可以讓開發(fā)者將組件中的邏輯提取出來,使得代碼更加清晰、可維護和可復(fù)用。
主要特點包括:
- 邏輯封裝:可以將特定的業(yè)務(wù)邏輯封裝在一個 hook 函數(shù)中,例如獲取數(shù)據(jù)、處理狀態(tài)等。
- 可復(fù)用性:一個 hook 可以在多個組件中復(fù)用,避免了重復(fù)代碼的編寫。
- 清晰的代碼結(jié)構(gòu):通過將相關(guān)邏輯集中在 hook 函數(shù)中,組件的代碼更加簡潔明了,易于理解和維護。
在這里解釋一下 例子中 hooks 的使用
useDog.ts中的 hook:- 封裝數(shù)據(jù)和邏輯:在
useDog.ts中,定義了一個函數(shù),這個函數(shù)實際上就是一個 hook。它封裝了與獲取狗狗圖片相關(guān)的數(shù)據(jù)(dogList)和邏輯(getDog函數(shù)用于獲取隨機狗狗圖片的 URL 并添加到dogList中)。 - 響應(yīng)式數(shù)據(jù):使用
reactive創(chuàng)建了響應(yīng)式的dogList,這樣當dogList的內(nèi)容發(fā)生變化時,使用這個數(shù)據(jù)的組件會自動更新視圖。 - 異步操作:
getDog函數(shù)中使用axios進行異步請求獲取隨機狗狗圖片的 URL,成功后將其添加到dogList中,如果出現(xiàn)錯誤則彈出錯誤提示。
- 封裝數(shù)據(jù)和邏輯:在
- 在
Person.vue中的使用:- 引入 hook:通過
import useDog from '@/hooks/useDog';引入useDoghook。 - 解構(gòu)賦值:使用解構(gòu)賦值
let { dogList, getDog } = useDog();獲取useDoghook 中返回的dogList和getDog函數(shù)。 - 模板中使用:在模板中,使用
v-for遍歷dogList來展示多個狗狗圖片,并且通過點擊按鈕觸發(fā)getDog函數(shù)來獲取新的狗狗圖片,從而更新視圖。
- 引入 hook:通過
綜上所述,這個例子展示了 Vue 3.0 中 hooks 的強大功能,通過封裝邏輯和數(shù)據(jù),提高了代碼的可維護性和可復(fù)用性,使得組件的開發(fā)更加高效和清晰。
到此這篇關(guān)于Vue 3.0 中 hooks 的概念的文章就介紹到這了,更多相關(guān)Vue 3.0 hooks內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue3中g(shù)etCurrentInstance示例講解
這篇文章主要給大家介紹了關(guān)于vue3中g(shù)etCurrentInstance的相關(guān)資料,文中還介紹了Vue3中關(guān)于getCurrentInstance的大坑,需要的朋友可以參考下2023-03-03
vue-cli3使用postcss-plugin-px2rem方式
這篇文章主要介紹了vue-cli3使用postcss-plugin-px2rem方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-07-07
使用開源Cesium+Vue實現(xiàn)傾斜攝影三維展示功能
這篇文章主要介紹了使用開源Cesium+Vue實現(xiàn)傾斜攝影三維展示,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-07-07
Vue2實現(xiàn)子組件修改父組件值的方法小結(jié)
在 Vue 2 中,子組件不能直接修改父組件的值,因為 Vue 遵循單向數(shù)據(jù)流的原則,為了實現(xiàn)子組件修改父組件的數(shù)據(jù),本文給大家介紹了Vue2實現(xiàn)子組件修改父組件值的四種方法,并通過代碼示例講解的非常詳細,需要的朋友可以參考下2025-03-03
unplugin-vue-components解決命名沖突問題
這篇文章主要介紹了unplugin-vue-components解決命名沖突問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-03-03

