欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue3中的setup語法糖、computed函數(shù)、watch函數(shù)詳解

 更新時間:2023年03月01日 14:58:23   作者:幾何心涼  
這篇文章主要介紹了Vue3中的setup語法糖、computed函數(shù)、watch函數(shù),本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

?? 寫在前面

專欄介紹:
涼哥作為 Vue 的忠實 粉絲輸出過大量的 Vue 文章,應(yīng)粉絲要求開始更新 Vue3 的相關(guān)技術(shù)文章,Vue 框架目前的地位大家應(yīng)該都曉得,所謂三大框架使用人數(shù)最多,公司選型最多的框架,涼哥之前在文章中也提到過就是 Vue 框架之所以火起來的原因,和 Vue 框架相比其他框架的巨大優(yōu)勢,有興趣的伙伴可以看一下Vue與React的區(qū)別和優(yōu)勢對比,隨著 Vue 框架不斷的被認(rèn)可,現(xiàn)如今的 Vue 框架已經(jīng)是前端工程師必備的技能了,記得尤大大開發(fā) Vue 的初衷,為了讓自己的開發(fā)工作更加便捷,也希望這個框架能讓更多人的開發(fā)工作變得輕松;現(xiàn)如今 Vue 框架做到了,尤大大做到了,當(dāng)然在 20 年的 9 月 18 日,Vue 又向前端同僚們報告了一次大的突破 Vue3.0 版本正式發(fā)布!如今已經(jīng)過去了兩年多的時間,更多的公司選擇了Vue3技術(shù),所以涼哥也在這個時候為大家出這份專欄,本專欄將幫助大家掌握Vue3+TS技術(shù),提升自己競爭力!

溫故知新:
上篇文章文章中我們了解到入口函數(shù)setup以及Vue3的響應(yīng)式數(shù)據(jù)的轉(zhuǎn)化函數(shù)reactive、ref,以及這兩個函數(shù)我們在項目開發(fā)中如何進(jìn)行選擇!本篇博客中為大家呈現(xiàn) setup的語法糖,讓我們省去重復(fù)的代碼工作,高效開發(fā),并且?guī)ьI(lǐng)大家掌握 computed、watch 函數(shù)的使用!讓我們 let’s coding!

?? setup 語法糖

大家發(fā)現(xiàn)沒有,在我們前面幾篇文章中的案例代碼中,每個案例的模板中都有一些雷同代碼,這些代碼就是我們的setup函數(shù),但是作為組合API的入口函數(shù),我們所有的組合式API都要寫到里面,難道我們每次都要寫上這一坨么,其實在Vue中提供了setup 的語法糖,語法糖大家都知道是什么嘛?就比如我們Vue2中的 v-model 不就是語法糖么,可以通過這樣一個指令省去了大量的雙向數(shù)據(jù)綁定的代碼!那我們來看一下我們的setup都夠簡化成為什么樣子,以下面代碼為例,我們聲明一個函數(shù),點擊按鈕觸發(fā)喊出打印 hi 這樣一個簡單的效果;

<template>
    <div>
        <button @click="hello">hello</button>
    </div>
</template>

<script>
export default {
    setup() {
        const hello = () => {
            console.log('hi')
        }

        return { hello }
    }
}
</script>
<template>
    <div>
        <button @click="hello">hello</button>
    </div>
</template>

<script setup>
const hello = () => {
    console.log('hi')
}
</script>

上面是我們使用setup語法糖后的代碼效果,功能實現(xiàn)上是一樣的;在 script setup 的標(biāo)簽中,所有的數(shù)據(jù)、函數(shù)可以直接在模板中使用!大家可以多多嘗試一下,可以將我們 Vue3通透教程【四】文章中的例子使用setup語法糖的方式進(jìn)行改造一下!

在 script setup 中的頂層變量都可以直接在模板中使用

?? computed函數(shù)

在上篇文章中我們學(xué)了兩個組合式API分別是 ref 和 reactive,現(xiàn)在呢我們學(xué)習(xí)cmputed函數(shù),相信大家一定知道他即使我們的計算數(shù)據(jù)定義函數(shù),之前呢是 computed 選項,現(xiàn)在是computed函數(shù);我們來通過小案例來體驗一下吧!computed 函數(shù)的使用:其實我們什么情況下會使用計算屬性呢,那一定是通過依賴的數(shù)據(jù)得到新的數(shù)據(jù)!

1)從Vue中引入computed
2)在setup中進(jìn)行使用,將一個函數(shù),函數(shù)的返回值就是計算好的數(shù)據(jù)
3)最后呢通過setup返回出去,模板進(jìn)行使用,如果使用setup語法糖后其實不需要這一步了

我們可以舉一個簡單的例子,比如我們定義一個成績數(shù)字,單純的分?jǐn)?shù)信息,那我們通過 computed 函數(shù)來為我們計算出超過60份的及格成績;我們就直接使用 script setup 的方式來編碼了哈!

<template>
    <div>
        <p>成績單</p>
        <a v-for="num in achievement"> {{ num }} / </a>
        <p>及格成績單</p>
        <a v-for="num in passList"> {{ num }} / </a>
    </div>
</template>

<script setup>
import { computed, ref } from 'vue';

const achievement = ref([44, 22, 66, 77, 99, 88, 70, 21])

const passList = computed(() => {
    return achievement.value.filter(item => item > 60)
})
</script>

?? watch 函數(shù)

跟computed函數(shù)一樣,watch函數(shù)也是組合式API中的一員,watch其實就是監(jiān)聽數(shù)據(jù)變化的函數(shù),那么在Vue3中它都有哪些用法呢?可以使用watch監(jiān)聽一個或者多個響應(yīng)式數(shù)據(jù),可以使用watch監(jiān)聽響應(yīng)式數(shù)據(jù)中的一個屬性(簡單數(shù)據(jù) or 復(fù)雜數(shù)據(jù))可以配置深度監(jiān)聽,也可以使用watch監(jiān)聽實現(xiàn)默認(rèn)執(zhí)行;我們來分開嘗試一下代碼的寫法

通過watch監(jiān)聽一個數(shù)據(jù)

watcha監(jiān)聽一個數(shù)據(jù),函數(shù)兩個參數(shù):第一個要監(jiān)聽的數(shù)據(jù),第二個參數(shù)是監(jiān)聽值發(fā)生變化后觸發(fā)的回調(diào)函數(shù),其中回調(diào)函數(shù)也有兩個參數(shù) 新值、老值

<template>
    <div>
        總贊數(shù):{{ num }} <button @click="num++">點贊</button>
    </div>
</template>

<script setup>
import { ref, watch } from 'vue';

//創(chuàng)建一個響應(yīng)式數(shù)據(jù),我們通過點贊按鈕改變num的值

const num = ref(0)
watch(num, (nv, ov) => {
    console.log(nv, ov)
})
</script>

通過watch監(jiān)聽多個數(shù)據(jù)

watcha監(jiān)聽多個數(shù)據(jù),例如下面的我們需要監(jiān)聽num和user對象的變化,函數(shù)兩個參數(shù):第一個要監(jiān)聽的數(shù)據(jù)(因為是多個數(shù)據(jù)所以用數(shù)組),第二個參數(shù)是監(jiān)聽值發(fā)生變化后觸發(fā)的回調(diào)函數(shù)。

<template>
    <div>
        總贊數(shù):{{ num }} <button @click="num++">點贊</button>
    </div>
    <p>姓名:{{ user.name }}</p>
    <p>年齡:{{ user.age }}</p>
    <button @click="user.age++">過年啦</button>
</template>

<script setup>
import { ref, watch, reactive } from 'vue';
const num = ref(0)
let user = reactive(
    {
        name: "幾何心涼",
        age: 18
    }
)
watch([num, user], () => {
    console.log('我監(jiān)聽到了')
})
</script>

通過watch監(jiān)聽對象的一個屬性(簡單類型)

watch監(jiān)聽對象的一個屬性并且是簡單類型的屬性,比如我們監(jiān)聽下面的user中的age值,他是一個簡單類型,那我們watch的第一個參數(shù)形式需要是將對象屬性作為返回值的函數(shù);第二個參數(shù)是改變后的回調(diào)函數(shù)。

<template>
    <p>姓名:{{ user.name }}</p>
    <p>年齡:{{ user.age }}</p>
    <button @click="user.age++">過年啦</button>
</template>

<script setup>
import { ref, watch, reactive } from 'vue';
let user = reactive(
    {
        name: "幾何心涼",
        age: 18
    }
)
watch(()=>user.age, () => {
    console.log('我監(jiān)聽到了user.age的變化')
})
</script>

通過watch監(jiān)聽對象的一個屬性(復(fù)雜類型)

watch監(jiān)聽對象的一個屬性并且是復(fù)雜類型的屬性,比如下面的我們要監(jiān)聽user中的info,我們嘗試一下改變user中info中的wages值,那我們watch的第一個參數(shù)形式需要是將對象屬性作為返回值的函數(shù);第二個參數(shù)是改變后的回調(diào)函數(shù)。這時候還需要第三個參數(shù)那就是 deep 開啟深度監(jiān)聽

<template>
    <p>姓名:{{ user.name }}</p>
    <p>年齡:{{ user.age }}</p>
    <p>薪資:{{ user.info.wages }}</p>
    <button @click="user.age++">過年啦</button>
    <button @click="user.info.wages+=2000">加薪了</button>
</template>

<script setup>
import { ref, watch, reactive } from 'vue';
let user = reactive(
    {
        name: "幾何心涼",
        age: 18,
        info:{
            wages:20000
        }
    }
)
watch(()=>user.info, () => {
    console.log('我監(jiān)聽到了user.info的變化')
},{
    deep:true
})
</script>

通過watch監(jiān)聽數(shù)據(jù)默認(rèn)執(zhí)行

其實這種情況并不多但是也會遇到這種情況,就是我們在監(jiān)聽數(shù)據(jù)變化的時候,先默認(rèn)執(zhí)行一次;其實就是添加我們的immediate參數(shù)為true,我們以最初的num為例哈!

<template>
    <div>
        總贊數(shù):{{ num }} <button @click="num++">點贊</button>
    </div>
</template>

<script setup>
import { ref, watch, reactive } from 'vue';
const num = ref(0)
watch(num, () => {
    console.log('我打印了')
},{
    immediate:true
})
</script>

?? 寫在最后

掌握了setup語法糖,我們編碼更便捷,并且?guī)ьI(lǐng)大家掌握 computed、watch 函數(shù)的使用,希望大家能夠自己實現(xiàn)上面的案例功能哦,做到真正的掌握這些點!下一篇文章中我們將帶領(lǐng)大家學(xué)習(xí)Vue3的生命周期,拭目以待吧!各位小伙伴讓我們 let’s coding!

到此這篇關(guān)于Vue3中的setup語法糖、computed函數(shù)、watch函數(shù)的文章就介紹到這了,更多相關(guān)Vue3 setup語法糖內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • axios取消請求與避免重復(fù)請求

    axios取消請求與避免重復(fù)請求

    在項目中經(jīng)常有一些場景會連續(xù)發(fā)送多個請求,而異步會導(dǎo)致最后得到的結(jié)果不是我們想要的,并且對性能也有非常大的影響,這篇文章主要給大家介紹了關(guān)于axios取消請求與避免重復(fù)請求的相關(guān)資料,需要的朋友可以參考下
    2021-06-06
  • 分分鐘學(xué)會vue中vuex的應(yīng)用(入門教程)

    分分鐘學(xué)會vue中vuex的應(yīng)用(入門教程)

    本篇文章主要介紹了vue中vuex的應(yīng)用(入門教程),詳細(xì)的介紹了vuex.js和應(yīng)用方法,有興趣的可以了解一下
    2017-09-09
  • vue綜合組件間的通信詳解

    vue綜合組件間的通信詳解

    這篇文章主要為大家詳細(xì)介紹了vue綜合組件間的通信,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • 使用Vue.$set()或者Object.assign()修改對象新增響應(yīng)式屬性的方法

    使用Vue.$set()或者Object.assign()修改對象新增響應(yīng)式屬性的方法

    vue代碼中,只要在data對象里定義的對象,賦值后,任意一個屬性值發(fā)生變化,視圖都會實時變化,這篇文章主要介紹了使用Vue.$set()或者Object.assign()修改對象新增響應(yīng)式屬性,需要的朋友可以參考下
    2022-12-12
  • Vue+Vant實現(xiàn)7天日歷展示并在切換日期時實時變換功能

    Vue+Vant實現(xiàn)7天日歷展示并在切換日期時實時變換功能

    本文介紹了如何利用Vue和Vant框架結(jié)合moment.js插件來實現(xiàn)一個7天日歷展示功能,在這個功能中,用戶可以在切換日期時看到界面的實時變化,此外,文章還提供了代碼實現(xiàn)和效果測試的詳細(xì)步驟,幫助開發(fā)者能夠順利完成類似的項目開發(fā)
    2024-10-10
  • echarts 使用formatter 修改鼠標(biāo)懸浮事件信息操作

    echarts 使用formatter 修改鼠標(biāo)懸浮事件信息操作

    這篇文章主要介紹了echarts 使用formatter 修改鼠標(biāo)懸浮事件信息操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • Hexo已經(jīng)看膩了,來手把手教你使用VuePress搭建個人博客

    Hexo已經(jīng)看膩了,來手把手教你使用VuePress搭建個人博客

    vuepress是尤大大4月12日發(fā)布的一個全新的基于vue的靜態(tài)網(wǎng)站生成器,實際上就是一個vue的spa應(yīng)用,內(nèi)置webpack,可以用來寫文檔。這篇文章給大家介紹了VuePress搭建個人博客的過程,感興趣的朋友一起看看吧
    2018-04-04
  • vue+element table表格實現(xiàn)動態(tài)列篩選的示例代碼

    vue+element table表格實現(xiàn)動態(tài)列篩選的示例代碼

    這篇文章主要介紹了vue+element table表格實現(xiàn)動態(tài)列篩選的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • Vue自定義事件(詳解)

    Vue自定義事件(詳解)

    下面小編就為大家?guī)硪黄猇ue自定義事件(詳解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • vue中v-bind和v-model的區(qū)別詳解

    vue中v-bind和v-model的區(qū)別詳解

    v-bind和v-model是Vue.js中的兩個常用指令,它們在功能和用途上有一些區(qū)別,接下來小編就給大家具有講講vue中v-bind和v-model區(qū)別,感興趣的同學(xué)跟著小編一起來看看吧
    2023-08-08

最新評論