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

Vue中computed和watch的區(qū)別小結(jié)

 更新時間:2022年12月10日 11:13:01   作者:夢之歸途  
watch和computed都是以Vue的依賴追蹤機制為基礎的,當某一個依賴型數(shù)據(jù)發(fā)生變化的時候,所有依賴這個數(shù)據(jù)的相關數(shù)據(jù)會自動發(fā)生變化,即自動調(diào)用相關的函數(shù),來實現(xiàn)數(shù)據(jù)的變動,這篇文章簡單介紹下Vue中computed和watch的區(qū)別異同,感興趣的朋友一起看看吧

區(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ù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 100行代碼理解和分析vue2.0響應式架構(gòu)

    100行代碼理解和分析vue2.0響應式架構(gòu)

    通過100行代碼幫助大家理解和分析vue2.0響應式架構(gòu)的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • vue項目網(wǎng)頁自適應等比例放大縮小實例代碼

    vue項目網(wǎng)頁自適應等比例放大縮小實例代碼

    等比例縮放可以在不同的分辨率下都能夠一屏展示,不會有滾動條的問題,也不會有適配問題,下面這篇文章主要給大家介紹了關于vue項目網(wǎng)頁自適應等比例放大縮小的相關資料,需要的朋友可以參考下
    2022-11-11
  • vue3+axios封裝攔截器方式

    vue3+axios封裝攔截器方式

    介紹了如何在Vue項目中使用Axios封裝請求、配置攔截器,并在api.js中統(tǒng)一管理API接口,同時,也講解了如何在vite.config.js中配置解決跨域問題,這些操作可以優(yōu)化前端代碼結(jié)構(gòu),提高開發(fā)效率
    2024-09-09
  • 一文教你學會在Vue3中自定義指令

    一文教你學會在Vue3中自定義指令

    這篇文章主要為大家詳細介紹一下如何在Vue3中實現(xiàn)自定義指令,文中的示例代碼講解詳細,具有一定的借鑒價值,需要的同學可以參考一下
    2022-07-07
  • vue框架中props的typescript用法詳解

    vue框架中props的typescript用法詳解

    typescript 為 javaScript的超集,這意味著它支持所有都JavaScript都語法。這篇文章主要介紹了vue框架中props的typescript用法,需要的朋友可以參考下
    2020-02-02
  • Vue.js 實現(xiàn)微信公眾號菜單編輯器功能(二)

    Vue.js 實現(xiàn)微信公眾號菜單編輯器功能(二)

    這篇文章主要介紹了Vue.js 實現(xiàn)微信公眾號菜單編輯器功能,非常不錯,具有一定的參考借鑒價值,需要的朋友參考下吧
    2018-05-05
  • Vue Router應用方法詳解

    Vue Router應用方法詳解

    在看這篇文章的幾點要求:需要你先知道Vue-Router是個什么東西,用來解決什么問題,以及它的基本使用。如果你還不懂的話,建議上官網(wǎng)了解下Vue-Router的基本使用后再回來看這篇文章
    2022-09-09
  • Vue中emit事件無法觸發(fā)的問題及解決

    Vue中emit事件無法觸發(fā)的問題及解決

    這篇文章主要介紹了Vue中emit事件無法觸發(fā)的問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • Vue中如何實現(xiàn)proxy代理

    Vue中如何實現(xiàn)proxy代理

    本篇文章主要介紹了Vue中如何實現(xiàn)proxy代理,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-04-04
  • webpack 3 + Vue2 使用dotenv配置多環(huán)境的步驟

    webpack 3 + Vue2 使用dotenv配置多環(huán)境的步驟

    這篇文章主要介紹了webpack 3 + Vue2 使用dotenv配置多環(huán)境,env文件在配置文件都可以用, vue頁面用的時候需要在 webpack.base.conf.js 重新配置,需要的朋友可以參考下
    2023-11-11

最新評論