亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue?3.0?中?hooks?的概念示例詳解

 更新時(shí)間:2024年10月24日 12:12:00   作者:執(zhí)鍵行天涯  
在Vue3.0框架中,hooks函數(shù)允許將組件邏輯抽離復(fù)用,提高代碼的可維護(hù)性和復(fù)用性,通過封裝邏輯如獲取數(shù)據(jù)、處理狀態(tài)等,hooks使得組件開發(fā)更加高效和清晰,示例中,useDog.ts用于獲取狗狗圖片,展示了hooks封裝數(shù)據(jù)和邏輯、響應(yīng)式數(shù)據(jù)和異步操作的能力

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

一、示例

App.vue

<template>
  <Person/>
</template>
<script lang="ts" setup name="App"> //當(dāng)前根組件的組件名
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中使用上面的兩個(gè)組件;

<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"> 點(diǎn)我換小狗</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>

展示效果

在這個(gè)例子中,很好地展示了 Vue 3.0 中 hooks 的概念及使用方式。

二、Vue 3.0 中 hooks 的概念

Hooks 是一組以 use 開頭的函數(shù),用于在 Vue 3 的函數(shù)式組件(使用 setup 函數(shù)的組件)中封裝和復(fù)用有狀態(tài)的邏輯。它們可以讓開發(fā)者將組件中的邏輯提取出來,使得代碼更加清晰、可維護(hù)和可復(fù)用。

主要特點(diǎn)包括:

  • 邏輯封裝:可以將特定的業(yè)務(wù)邏輯封裝在一個(gè) hook 函數(shù)中,例如獲取數(shù)據(jù)、處理狀態(tài)等。
  • 可復(fù)用性:一個(gè) hook 可以在多個(gè)組件中復(fù)用,避免了重復(fù)代碼的編寫。
  • 清晰的代碼結(jié)構(gòu):通過將相關(guān)邏輯集中在 hook 函數(shù)中,組件的代碼更加簡潔明了,易于理解和維護(hù)。

在這里解釋一下 例子中 hooks 的使用

  • useDog.ts中的 hook:
    • 封裝數(shù)據(jù)和邏輯:在 useDog.ts 中,定義了一個(gè)函數(shù),這個(gè)函數(shù)實(shí)際上就是一個(gè) hook。它封裝了與獲取狗狗圖片相關(guān)的數(shù)據(jù)(dogList)和邏輯(getDog 函數(shù)用于獲取隨機(jī)狗狗圖片的 URL 并添加到 dogList 中)。
    • 響應(yīng)式數(shù)據(jù):使用 reactive 創(chuàng)建了響應(yīng)式的 dogList,這樣當(dāng) dogList 的內(nèi)容發(fā)生變化時(shí),使用這個(gè)數(shù)據(jù)的組件會(huì)自動(dòng)更新視圖。
    • 異步操作getDog 函數(shù)中使用 axios 進(jìn)行異步請求獲取隨機(jī)狗狗圖片的 URL,成功后將其添加到 dogList 中,如果出現(xiàn)錯(cuò)誤則彈出錯(cuò)誤提示。
  • Person.vue 中的使用:
    • 引入 hook:通過 import useDog from '@/hooks/useDog'; 引入 useDog hook。
    • 解構(gòu)賦值:使用解構(gòu)賦值 let { dogList, getDog } = useDog(); 獲取 useDog hook 中返回的 dogListgetDog 函數(shù)。
    • 模板中使用:在模板中,使用 v-for 遍歷 dogList 來展示多個(gè)狗狗圖片,并且通過點(diǎn)擊按鈕觸發(fā) getDog 函數(shù)來獲取新的狗狗圖片,從而更新視圖。

綜上所述,這個(gè)例子展示了 Vue 3.0 中 hooks 的強(qiáng)大功能,通過封裝邏輯和數(shù)據(jù),提高了代碼的可維護(hù)性和可復(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示例講解

    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方式

    這篇文章主要介紹了vue-cli3使用postcss-plugin-px2rem方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • 使用開源Cesium+Vue實(shí)現(xiàn)傾斜攝影三維展示功能

    使用開源Cesium+Vue實(shí)現(xiàn)傾斜攝影三維展示功能

    這篇文章主要介紹了使用開源Cesium+Vue實(shí)現(xiàn)傾斜攝影三維展示,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-07-07
  • Vue2實(shí)現(xiàn)子組件修改父組件值的方法小結(jié)

    Vue2實(shí)現(xiàn)子組件修改父組件值的方法小結(jié)

    在 Vue 2 中,子組件不能直接修改父組件的值,因?yàn)?nbsp;Vue 遵循單向數(shù)據(jù)流的原則,為了實(shí)現(xiàn)子組件修改父組件的數(shù)據(jù),本文給大家介紹了Vue2實(shí)現(xiàn)子組件修改父組件值的四種方法,并通過代碼示例講解的非常詳細(xì),需要的朋友可以參考下
    2025-03-03
  • Nuxt不同環(huán)境如何區(qū)分的方法

    Nuxt不同環(huán)境如何區(qū)分的方法

    在一般情況下,我們的項(xiàng)目肯定需要區(qū)分不同環(huán)境,那么Nuxt提供給我們這樣的基本能力了么,下面我們就一起來了解一下
    2021-05-05
  • vue兄弟組件傳遞數(shù)據(jù)的實(shí)例

    vue兄弟組件傳遞數(shù)據(jù)的實(shí)例

    今天小編就為大家分享一篇vue兄弟組件傳遞數(shù)據(jù)的實(shí)例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • Vue中使用裝飾器的方法詳解

    Vue中使用裝飾器的方法詳解

    裝飾器是一種與類相關(guān)的語法糖,用來包裝或者修改類或者類的方法的行為,其實(shí)裝飾器就是設(shè)計(jì)模式中裝飾者模式的一種實(shí)現(xiàn)方式,下面這篇文章主要給大家介紹了關(guān)于Vue中使用裝飾器的相關(guān)資料,需要的朋友可以參考下
    2022-01-01
  • VUE遞歸樹形實(shí)現(xiàn)多級列表

    VUE遞歸樹形實(shí)現(xiàn)多級列表

    這篇文章主要為大家詳細(xì)介紹了VUE遞歸樹形實(shí)現(xiàn)多級列表,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • unplugin-vue-components解決命名沖突問題

    unplugin-vue-components解決命名沖突問題

    這篇文章主要介紹了unplugin-vue-components解決命名沖突問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Vue之定義全局工具類問題

    Vue之定義全局工具類問題

    這篇文章主要介紹了Vue之定義全局工具類問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05

最新評論