vue中watch和computed的區(qū)別詳解
今天給大家講一下watch跟computed的區(qū)別,下面我們直接開始吧
- 功能上:computed是計(jì)算屬性,watch是監(jiān)聽一個(gè)值的變化,然后執(zhí)行對(duì)應(yīng)的回調(diào)。
- 是否調(diào)用緩存:computed中的函數(shù)所依賴的屬性沒有發(fā)生變化,那么調(diào)用當(dāng)前的函數(shù)的時(shí)候會(huì)從緩存中讀取,而watch在每次監(jiān)聽的值發(fā)生變化的時(shí)候都會(huì)執(zhí)行回調(diào)。
- 是否調(diào)用return:computed中的函數(shù)必須要用return返回,watch中的函數(shù)不是必須要用return。
- computed默認(rèn)第一次加載的時(shí)候就開始監(jiān)聽;watch默認(rèn)第一次加載不做監(jiān)聽,如果需要第一次加載做監(jiān)聽,添加immediate屬性,設(shè)置為true(immediate:true)
- 使用場(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)
<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)
<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)
通過本文給您演示一下如何有效地使用遞歸組件,我將通過建立一個(gè)可擴(kuò)展/收縮的樹形菜單的來一步步進(jìn)行。下面通過本文給大家分享用 Vue.js 遞歸組件實(shí)現(xiàn)可折疊的樹形菜單,需要的朋友參考下吧2017-12-12Vue 父子組件的數(shù)據(jù)傳遞、修改和更新方法
下面小編就為大家分享一篇Vue 父子組件的數(shù)據(jù)傳遞、修改和更新方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-03-03vue.js選中動(dòng)態(tài)綁定的radio的指定項(xiàng)
這篇文章主要介紹了vue.js選中動(dòng)態(tài)綁定的radio的指定項(xiàng),需要的朋友可以參考下2017-06-06淺談validator自定義驗(yàn)證及易錯(cuò)點(diǎn)
這篇文章主要介紹了validator自定義驗(yàn)證及易錯(cuò)點(diǎn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-02-02vue components 動(dòng)態(tài)組件詳解
這篇文章主要介紹了vue components 動(dòng)態(tài)組件,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-11-11VueCli4項(xiàng)目配置反向代理proxy的方法步驟
這篇文章主要介紹了VueCli4項(xiàng)目配置反向代理proxy的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05