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

Vue中的methods、watch、computed的區(qū)別

 更新時間:2018年11月26日 09:27:42   作者:william  
這篇文章主要介紹了Vue中的methods、watch、computed的區(qū)別,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

看到這個標題就知道這篇文章接下來要講的內(nèi)容,我們在使用vue的時候methods、watch、computed這三個特性一定經(jīng)常使用,因為它們是非常的有用,但是沒有徹底的理解它們的區(qū)別和各自的使用場景,也很難用好它們,希望接下來的介紹為你答疑解惑。

computed

我們先來看計算屬性:computed,光看名字也知道是用來干什么的,計算屬性當然是用來計算的,但是是怎么計算的呢?計算屬性有兩個顯著的特點:

  • 計算屬性計算時所依賴的屬性一定是響應(yīng)式依賴,否則計算屬性不會執(zhí)行
  • 計算屬性是基于依賴進行緩存的,就是說在依賴沒有更新的情況,調(diào)用計算屬性并不會重新計算,可以減少開銷

我們來看一個相關(guān)的例子:

<div id="app">
 <div>{{ arr.join('') }}</div>
 <div>{{ arr1 }}</div>
 <div>{{ getDate }}</div>
 <div>{{ getDate1 }}</div>
</div>
var app = new Vue({
 el: '#app',
 data: {
  date: '',
  arr: ['a', 'b', 'c']
 },
 computed: {
  getDate () {
   return Date.now()
  },
  getDate1 () {
   return this.date
  },
  arr1 () {
   return this.arr.join('')
  }
 },
 created () {
  setInterval(() => {
   this.date = Date.now()
  }, 1000)
 }
})

看上面的例子,我們在寫vue的時候,經(jīng)常會碰到要對data的值進行操作的情況,為了方便,總是會有人直接在模版中對data的值進行計算操作,就像我上面例子中寫的在模版中將數(shù)組轉(zhuǎn)化為字符串,這樣寫有問題嗎?語法沒有問題,但是在模版中使用太多的計算,維護會是個問題,換個人來看代碼的時候會很痛苦,這種寫法就好像在html中插入js的邏輯運算,可維護性極差。另外一個展示的就是computed的響應(yīng)式依賴的問題,當我們調(diào)用getDate的時候返回的Date.now()返回的是一個非響應(yīng)式的依賴因此getDate返回的值不會變。

應(yīng)用場景

看了computed的特點之后,那么它的應(yīng)用場景是什么呢?個人看法,但不限于以下場景:

  • 復(fù)雜的渲染數(shù)據(jù)計算,用computed計算屬性可以減少一定計算開銷,增加可維護性
  • 從Vuex Store中收集相關(guān)信息,對Vuex中的數(shù)據(jù)做計算的時候的要特別注意computed的緩存屬性,在對Vuex中的對象值進行屬性修改的時候,并不會觸發(fā)computed的中值的變化,這時需要Object.assign({},obj)對依賴對象進行跟新返回一個新對象觸發(fā)依賴跟新
  • 表單校驗,這個應(yīng)用場景應(yīng)該是比較常見的,利用正則表達式對每個表單項的實時監(jiān)控,判斷表單是否可以提交

methods

methods大家應(yīng)該都會用,是vue中的方法屬性,所有的方法調(diào)用都會寫到這里面,大家用的最多也是在累似@click這樣事件調(diào)用中使用,但是很多人都忽視methods的另一個用法,就是在模版中使用methods,下面來看一個例子:

<div id="app">
 <div v-for="(item, idx) in arr">
  {{ matching(item) }}
 </div>
</div>
var app = new Vue({
 el: '#app',
 data: {
  arr: ['a', 'b', 'c'],
  obj: {a: 'hello', b: 'world'}
 },
 methods: {
  matching (key) {
   if (this.obj[key]) {
    return this.obj[key]
   } else {
    return 'not found'
   }
  }
 }
})

上面的例子就是methods在模版中常常使用的一個場景,當模版中的某個循環(huán)的值需要進行一定邏輯運算時,這時候你就可以使用methods方法,將對應(yīng)的值傳入,然后計算出結(jié)果返回到模版顯示,這個時候用computed是沒法實現(xiàn)的,computed中你無法傳參,methods和computed除了這個不一樣之外,還有就是在methods中的計算是不會做緩存的,也就是你調(diào)用多少次就會計算多少次,相對computed的開銷要大一些。

watch

偵聽屬性是專門用來觀察和響應(yīng)vue實例上的數(shù)據(jù)變動,能使用watch屬性的場景基本上都可以使用computed屬性,而且computed屬性開銷小,性能高,因此能使用computed就盡量使用computed屬性,那么watch屬性是不是就沒用武之地了呢?當執(zhí)行異步操作的時候你可能就必須用watch而不是computed了,下面看一個例子:

<div id="app">
 <div>{{ obj1.a }}</div>
</div>
var app = new Vue({
 el: '#app',
 data: {
  obj: {a: 'hello'},
  obj1: {a: 'hello'},
  test: 'aaa'
 },
 computed: {
  getObj () {
   setTimeout(() => {
    this.obj.a = this.test + 'word'
    return this.obj
   }, 1000)
  }
 },
 watch: {
  test () {
   setTimeout(() => {
    this.obj1.a = this.test + 'word'
   }, 1000)
  }
 },
 mounted () {
  this.test = 'hello'
 }
})

上述例子中,當在模版中調(diào)用getObj.a時,如果沒有setTimeout這異步操作,直接返回一個值是可以直接在模版中顯示的,但是由于加異步操作就會導(dǎo)致沒有返回值同時調(diào)用對象的屬性,就會報錯,而調(diào)用obj1.a卻不一樣,模版會先顯示hello,然后在觸發(fā)了watch屬性時,setTimeout觸發(fā),一秒鐘之后模版會顯示helloword,這就watch中可以使用異步函數(shù),而computed不行的原因

總結(jié)

希望看了這篇文章能對你區(qū)分methods、computed、watch的用法能有所幫助。

這篇文章如果有錯誤或不嚴謹?shù)牡胤?,歡迎批評指正,如果喜歡,歡迎點贊收藏

相關(guān)文章

  • vue實現(xiàn)選項卡及選項卡切換效果

    vue實現(xiàn)選項卡及選項卡切換效果

    這篇文章主要介紹了vue實現(xiàn)選項卡選項卡切換效果,這里的Vue以單文件的形式引入,另外代碼在實現(xiàn)上會一步步的進行優(yōu)化。需要的朋友可以參考下
    2018-04-04
  • vue3項目如何使用prettier格式化代碼

    vue3項目如何使用prettier格式化代碼

    這篇文章主要介紹了vue3項目如何使用prettier格式化代碼問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • 詳解win7 cmd執(zhí)行vue不是內(nèi)部命令的解決方法

    詳解win7 cmd執(zhí)行vue不是內(nèi)部命令的解決方法

    這篇文章主要介紹了詳解win7 cmd執(zhí)行vue不是內(nèi)部命令的解決方法的相關(guān)資料,這里提供了解決問題的詳細步驟,具有一定的參考價值,需要的朋友可以參考下
    2017-07-07
  • vue中實現(xiàn)點擊按鈕滾動到頁面對應(yīng)位置的方法(使用c3平滑屬性實現(xiàn))

    vue中實現(xiàn)點擊按鈕滾動到頁面對應(yīng)位置的方法(使用c3平滑屬性實現(xiàn))

    這篇文章主要介紹了vue中實現(xiàn)點擊按鈕滾動到頁面對應(yīng)位置的方法,這段代碼主要使用c3平滑屬性實現(xiàn),需要的朋友可以參考下
    2019-12-12
  • Vue中slot插槽作用與原理詳解

    Vue中slot插槽作用與原理詳解

    插槽slot可以說在一個Vue項目里面處處都有它的身影,比如我們使用一些UI組件庫的時候,我們通??梢允褂貌宀蹃碜远x我們的內(nèi)容,這篇文章主要介紹了Vue3中slot插槽使用方式,需要的朋友可以參考下
    2022-09-09
  • vue音樂播放器插件vue-aplayer的配置及其使用實例詳解

    vue音樂播放器插件vue-aplayer的配置及其使用實例詳解

    本篇文章主要介紹了vue音樂播放器插件vue-aplayer的配置及其使用實例詳解,具有一定的參考價值,有興趣的可以了解一下
    2017-07-07
  • vue2如何實現(xiàn)vue3的teleport

    vue2如何實現(xiàn)vue3的teleport

    這篇文章主要介紹了vue2如何實現(xiàn)vue3的teleport,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • 基于Vue實現(xiàn)手勢簽名

    基于Vue實現(xiàn)手勢簽名

    這篇文章主要為大家詳細介紹了基于Vue實現(xiàn)手勢簽名,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • Vue3?Watch踩坑實戰(zhàn)之watch監(jiān)聽無效

    Vue3?Watch踩坑實戰(zhàn)之watch監(jiān)聽無效

    Vue.js中的watch選項用于監(jiān)聽Vue實例上某個特定的數(shù)據(jù)變化,下面這篇文章主要給大家介紹了關(guān)于Vue3?Watch踩坑實戰(zhàn)之watch監(jiān)聽無效的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-05-05
  • vue項目中使用rem替換px的實現(xiàn)示例

    vue項目中使用rem替換px的實現(xiàn)示例

    移動端頁面適配,rem和vw適配方案,本文主要介紹了vue項目中使用rem替換px的實現(xiàn)示例,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-07-07

最新評論