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

vue中watch和computed的區(qū)別詳解

 更新時(shí)間:2023年11月21日 10:30:51   作者:前端開發(fā)小司機(jī)  
這篇文章主要給大家介紹了關(guān)于vue中watch和computed區(qū)別的相關(guān)資料,computed和watch都是vue框架中的用于監(jiān)聽數(shù)據(jù)變化的屬性,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下

今天給大家講一下watch跟computed的區(qū)別,下面我們直接開始吧

  1. 功能上:computed是計(jì)算屬性,watch是監(jiān)聽一個(gè)值的變化,然后執(zhí)行對(duì)應(yīng)的回調(diào)。
  2. 是否調(diào)用緩存:computed中的函數(shù)所依賴的屬性沒有發(fā)生變化,那么調(diào)用當(dāng)前的函數(shù)的時(shí)候會(huì)從緩存中讀取,而watch在每次監(jiān)聽的值發(fā)生變化的時(shí)候都會(huì)執(zhí)行回調(diào)。
  3. 是否調(diào)用return:computed中的函數(shù)必須要用return返回,watch中的函數(shù)不是必須要用return。
  4. computed默認(rèn)第一次加載的時(shí)候就開始監(jiān)聽;watch默認(rèn)第一次加載不做監(jiān)聽,如果需要第一次加載做監(jiān)聽,添加immediate屬性,設(shè)置為true(immediate:true)
  5. 使用場(chǎng)景:computed----當(dāng)一個(gè)屬性受多個(gè)屬性影響的時(shí)候,使用computed-----購(gòu)物車商品結(jié)算。watch–當(dāng)一條數(shù)據(jù)影響多條數(shù)據(jù)的時(shí)候,使用watch-----搜索框.

watch的實(shí)現(xiàn)

image.png

<body>
    <div id="app">
        姓: <input type="text" v-model=firstName> 名:
        <input type="text" v-model=lastName> 姓名:
        <span>{{fullname}}</span>
    </div>
</body>
<script type="text/javascript">
    var app = new Vue({
        el: "#app",
        data: {
            firstName: 'z',
            lastName: 's',
            fullname: 'zs'
        },
        watch: {
            firstName(newval) {
?
                this.fullname = newval + this.lastName
            },
            lastName(newval) {
                this.fullname = this.firstName + newval
            }
?
        }
    })
?
</script> 

computed的實(shí)現(xiàn)

image.png

<body>
    <div id="app">
        姓: <input type="text" v-model=firstName> 名:
        <input type="text" v-model=lastName> 姓名:
        <span>{{fullname}}</span>
    </div>
</body>
<script type="text/javascript">
    var app = new Vue({
        el: "#app",
        data: {
            firstName: 'z',
            lastName: 's'
        },
        computed: {
            fullname() {
                return this.firstName + this.lastName
            }
        }
    })
?
</script> 

watch與computed區(qū)別總結(jié)

computed支持緩存,相依賴的數(shù)據(jù)發(fā)生改變才會(huì)重新計(jì)算;watch不支持緩存,只要監(jiān)聽的數(shù)據(jù)變化就會(huì)觸發(fā)相應(yīng)操作

computed不支持異步,當(dāng)computed內(nèi)有異步操作時(shí)是無法監(jiān)聽數(shù)據(jù)變化的;watch支持異步操作

computed屬性的屬性值是一函數(shù),函數(shù)返回值為屬性的屬性值,computed中每個(gè)屬性都可以設(shè)置set與get方法。watch監(jiān)聽的數(shù)據(jù)必須是data中聲明過或父組件傳遞過來的props中的數(shù)據(jù),當(dāng)數(shù)據(jù)變化時(shí),觸發(fā)監(jiān)聽器

最后

到此這篇關(guān)于vue中watch跟computed的區(qū)別詳解的文章就介紹到這了,更多相關(guān)watch跟computed區(qū)別內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 用 Vue.js 遞歸組件實(shí)現(xiàn)可折疊的樹形菜單(demo)

    用 Vue.js 遞歸組件實(shí)現(xiàn)可折疊的樹形菜單(demo)

    通過本文給您演示一下如何有效地使用遞歸組件,我將通過建立一個(gè)可擴(kuò)展/收縮的樹形菜單的來一步步進(jìn)行。下面通過本文給大家分享用 Vue.js 遞歸組件實(shí)現(xiàn)可折疊的樹形菜單,需要的朋友參考下吧
    2017-12-12
  • Vue 父子組件的數(shù)據(jù)傳遞、修改和更新方法

    Vue 父子組件的數(shù)據(jù)傳遞、修改和更新方法

    下面小編就為大家分享一篇Vue 父子組件的數(shù)據(jù)傳遞、修改和更新方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • vue.js選中動(dòng)態(tài)綁定的radio的指定項(xiàng)

    vue.js選中動(dòng)態(tài)綁定的radio的指定項(xiàng)

    這篇文章主要介紹了vue.js選中動(dòng)態(tài)綁定的radio的指定項(xiàng),需要的朋友可以參考下
    2017-06-06
  • vuex中store的action和mutations用法

    vuex中store的action和mutations用法

    這篇文章主要介紹了vuex中store的action和mutations用法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • 淺談validator自定義驗(yàn)證及易錯(cuò)點(diǎn)

    淺談validator自定義驗(yàn)證及易錯(cuò)點(diǎn)

    這篇文章主要介紹了validator自定義驗(yàn)證及易錯(cuò)點(diǎn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-02-02
  • vue components 動(dòng)態(tài)組件詳解

    vue components 動(dòng)態(tài)組件詳解

    這篇文章主要介紹了vue components 動(dòng)態(tài)組件,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-11-11
  • vue-cli V3.0版本的使用詳解

    vue-cli V3.0版本的使用詳解

    這篇文章主要介紹了vue-cli V3.0版本的使用詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-10-10
  • VueCli4項(xiàng)目配置反向代理proxy的方法步驟

    VueCli4項(xiàng)目配置反向代理proxy的方法步驟

    這篇文章主要介紹了VueCli4項(xiàng)目配置反向代理proxy的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-05-05
  • 深入理解vue.js中的v-if和v-show

    深入理解vue.js中的v-if和v-show

    這篇文章主要給大家深入的介紹了關(guān)于vue.js中v-if和v-show的相關(guān)資料,文中詳細(xì)介紹兩者的共同點(diǎn)和區(qū)別,通過圖文介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起看看吧。
    2017-06-06
  • electron最小化托盤設(shè)置

    electron最小化托盤設(shè)置

    本文主要介紹了electron最小化托盤設(shè)置,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04

最新評(píng)論