Vue中computed和watch的區(qū)別小結(jié)
區(qū)別:計算屬性computed支持緩存,只有依賴數(shù)據(jù)發(fā)生改變,才會重新進行計算;不支持異步,當computed內(nèi)有異步操作時無效,無法監(jiān)聽數(shù)據(jù)的變化。而監(jiān)聽屬性watch不支持緩存,數(shù)據(jù)變,直接會觸發(fā)相應的操作;支持異步。
一、Vue中computed和watch的區(qū)別
watch和computed都是以Vue的依賴追蹤機制為基礎的,它們都試圖處理這樣一件事情:當某一個或多個數(shù)據(jù)(稱它們?yōu)橐蕾嚁?shù)據(jù))發(fā)生變化的時候,所有依賴這些數(shù)據(jù)的 “相關” 數(shù)據(jù) “自動” 發(fā)生變化,也就是自動調(diào)用相關的函數(shù)去實現(xiàn)數(shù)據(jù)的變動。
二、computed計算屬性
支持緩存,只有依賴數(shù)據(jù)發(fā)生改變,才會重新進行計算;如果函數(shù)所依賴的屬性沒有發(fā)生變化,從緩存中讀取
必須有return返回
使用方法和data中的數(shù)據(jù)一樣,但是類似一個執(zhí)行方法
不支持異步,當computed內(nèi)有異步操作時無效,無法監(jiān)聽數(shù)據(jù)的變化;
computed是計算屬性,也就是依賴某個值或者props通過計算得來的數(shù)據(jù)
computed的值是在getter執(zhí)行之后進行緩存的,只有在它依賴的數(shù)據(jù)發(fā)生變化(依賴的數(shù)據(jù)可以是單個,也可以是多個)時,會重新調(diào)用getter來計算;
注意:就算data中沒有直接聲明要計算的變量,也可以直接在computed中寫入,如下示例:
<p id="app"> {{fullName}} </p> <script> var vm = new Vue({ el: '#app', data: { firstName: 'Foo', lastName: 'Bar', }, computed: { fullName: function () { return this.firstName + ' ' + this.lastName } } }) </script>
計算屬性默認只有g(shù)etter,可以在需要的時候自己設定setter(所有 getter 和 setter 的 this 上下文自動地綁定為 Vue 實例):
computed: { fullName: { // getter get: function () { return this.firstName + ' ' + this.lastName }, // setter set: function (newValue) { var names = newValue.split(' ') this.firstName = names[0] this.lastName = names[names.length - 1] } } } //這個時候在控制臺直接運行【vm.fullName = ‘bibi wang'】,相應的firstName和lastName也會改變。
(2)watch
1、不支持緩存,數(shù)據(jù)變,直接會觸發(fā)相應的操作;
2、支持異步操作;
3、watch是監(jiān)聽器,可以監(jiān)聽某一個數(shù)據(jù),然后執(zhí)行相應的操作;
4、監(jiān)聽的函數(shù)接收兩個參數(shù),第一個參數(shù)是最新的值;第二個參數(shù)是輸入之前的值;
5、watch的函數(shù)名必須和data中的數(shù)據(jù)名一致
6、watch中的函數(shù)有倆個參數(shù),新舊
7、watch中的函數(shù)是不需要調(diào)用的
8、只會監(jiān)聽數(shù)據(jù)的值是否發(fā)生改變,而不會去監(jiān)聽數(shù)據(jù)的地址是否發(fā)生改變,要深度監(jiān)聽需要配合deep:true屬性使用
9、immediate:true 頁面首次加載的時候做一次監(jiān)聽
var vm = new Vue({ el: '#app', data: { firstName: 'Foo', lastName: 'Bar', fullName: 'Foo Bar' }, watch: { firstName: function (newVal,oldVal) { this.fullName = newVal + ' ' + this.lastName console.log(newVal+'========='+oldVal)//Fooaaaa=========Foo }, lastName: function (newVal,oldVal) { this.fullName = this.firstName + ' ' + newVal console.log(newVal+'========='+oldVal)//Baraaaa=========Bar } } })
注意:如果data中沒有相應的屬性的話,是不能watch的,這點和computed不一樣。
三、區(qū)別
1、功能:computed是計算屬性,watch是監(jiān)聽一個值的變化而執(zhí)行對應的回調(diào)
2、是否調(diào)用緩存:computed函數(shù)所依賴的屬性不變的時候會調(diào)用緩存;watch每次監(jiān)聽的值發(fā)生變化時候都會調(diào)用回調(diào)
3、是否調(diào)用return:computed必須有;watch可以沒有
4、使用場景:computed當一個屬性受多個屬性影響的時候;例如購物車商品結(jié)算;watch當一條數(shù)據(jù)影響多條數(shù)據(jù)的時候,例如搜索框
5、是否支持異步:computed函數(shù)不能有異步;watch可以
總結(jié)
- 當多個屬性影響一個屬性的時候,建議用computed
- 當一個值發(fā)生變化之后,會引起一系列的操作(改變其他屬性值),這種情況就適合用watch
到此這篇關于Vue中computed和watch的區(qū)別小結(jié)的文章就介紹到這了,更多相關Vue中computed和watch的區(qū)別內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Vue.js 實現(xiàn)微信公眾號菜單編輯器功能(二)
這篇文章主要介紹了Vue.js 實現(xiàn)微信公眾號菜單編輯器功能,非常不錯,具有一定的參考借鑒價值,需要的朋友參考下吧2018-05-05webpack 3 + Vue2 使用dotenv配置多環(huán)境的步驟
這篇文章主要介紹了webpack 3 + Vue2 使用dotenv配置多環(huán)境,env文件在配置文件都可以用, vue頁面用的時候需要在 webpack.base.conf.js 重新配置,需要的朋友可以參考下2023-11-11