vue中watch和computed的區(qū)別詳解
今天給大家講一下watch跟computed的區(qū)別,下面我們直接開始吧
- 功能上:computed是計算屬性,watch是監(jiān)聽一個值的變化,然后執(zhí)行對應(yīng)的回調(diào)。
- 是否調(diào)用緩存:computed中的函數(shù)所依賴的屬性沒有發(fā)生變化,那么調(diào)用當(dāng)前的函數(shù)的時候會從緩存中讀取,而watch在每次監(jiān)聽的值發(fā)生變化的時候都會執(zhí)行回調(diào)。
- 是否調(diào)用return:computed中的函數(shù)必須要用return返回,watch中的函數(shù)不是必須要用return。
- computed默認(rèn)第一次加載的時候就開始監(jiān)聽;watch默認(rèn)第一次加載不做監(jiān)聽,如果需要第一次加載做監(jiān)聽,添加immediate屬性,設(shè)置為true(immediate:true)
- 使用場景:computed----當(dāng)一個屬性受多個屬性影響的時候,使用computed-----購物車商品結(jié)算。watch–當(dāng)一條數(shù)據(jù)影響多條數(shù)據(jù)的時候,使用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ā)生改變才會重新計算;watch不支持緩存,只要監(jiān)聽的數(shù)據(jù)變化就會觸發(fā)相應(yīng)操作
computed不支持異步,當(dāng)computed內(nèi)有異步操作時是無法監(jiān)聽數(shù)據(jù)變化的;watch支持異步操作
computed屬性的屬性值是一函數(shù),函數(shù)返回值為屬性的屬性值,computed中每個屬性都可以設(shè)置set與get方法。watch監(jiān)聽的數(shù)據(jù)必須是data中聲明過或父組件傳遞過來的props中的數(shù)據(jù),當(dāng)數(shù)據(jù)變化時,觸發(fā)監(jiān)聽器
最后
到此這篇關(guān)于vue中watch跟computed的區(qū)別詳解的文章就介紹到這了,更多相關(guān)watch跟computed區(qū)別內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
用 Vue.js 遞歸組件實(shí)現(xiàn)可折疊的樹形菜單(demo)
通過本文給您演示一下如何有效地使用遞歸組件,我將通過建立一個可擴(kuò)展/收縮的樹形菜單的來一步步進(jìn)行。下面通過本文給大家分享用 Vue.js 遞歸組件實(shí)現(xiàn)可折疊的樹形菜單,需要的朋友參考下吧2017-12-12Vue 父子組件的數(shù)據(jù)傳遞、修改和更新方法
下面小編就為大家分享一篇Vue 父子組件的數(shù)據(jù)傳遞、修改和更新方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-03-03