亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue中watch和computed的區(qū)別與使用方法

 更新時間:2020年08月23日 15:56:14   作者:Levy  
這篇文章主要給大家介紹了關(guān)于vue中watch和computed的區(qū)別與使用方法的相關(guān)資料,文中通過實(shí)例代碼結(jié)束的非常詳細(xì),對大家學(xué)習(xí)或者使用Vue具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧

computed 計(jì)算屬性說明:

computed 是基于響應(yīng)性依賴來進(jìn)行緩存的。只有依賴數(shù)據(jù)發(fā)生改變,才會重新進(jìn)行計(jì)算(當(dāng)觸發(fā)重新渲染,若依賴數(shù)據(jù)沒有改變,則 computed 不會重新計(jì)算)。若沒改變,計(jì)算屬性會立即返回之前緩存的計(jì)算結(jié)果。

不支持異步,當(dāng) computed 內(nèi)有異步操作時無效,無法監(jiān)聽數(shù)據(jù)的變化的值。

computed 中的成員可以只定義一個函數(shù)作為只讀屬性, 也可以定義成 get/set 變成可讀寫屬性

如果一個屬性是由其他屬性計(jì)算而來的,這個屬性依賴其他屬性,是一個多對一或者一對一,一般用 computed。

下面的計(jì)算屬性將不再更新,因?yàn)?Date.now() 不是響應(yīng)式依賴:

computed: {
 now: function () {
 return Date.now()
 }
}

相比之下,每當(dāng)觸發(fā)重新渲染時,調(diào)用方法將總會再次執(zhí)行函數(shù)。

我們?yōu)槭裁葱枰彺??假設(shè)我們有一個性能開銷比較大的計(jì)算屬性 A,它需要遍歷一個巨大的數(shù)組并做大量的計(jì)算。然后我們可能有其他的計(jì)算屬性依賴于 A。如果沒有緩存,我們將不可避免的多次執(zhí)行 A 的 getter!如果你不希望有緩存,請用方法來替代。

watch 監(jiān)聽屬性說明:

不支持緩存,數(shù)據(jù)變或者觸發(fā)重新渲染時,直接會觸發(fā)相應(yīng)的操作。

watch 支持異步

當(dāng)一個屬性發(fā)生變化時,需要執(zhí)行對應(yīng)的操作;一對多時,一般用 watch。

監(jiān)聽數(shù)據(jù)必須是 data 中聲明過或者父組件傳遞過來的 props 中的數(shù)據(jù),當(dāng)數(shù)據(jù)變化時,觸發(fā)其他操作,函數(shù)有兩個參數(shù),immediate:組件加載立即觸發(fā)回調(diào)函數(shù)執(zhí)行,deep: 深度監(jiān)聽,為了發(fā)現(xiàn)對象內(nèi)部值的變化,復(fù)雜類型的數(shù)據(jù)時使用,例如數(shù)組中的對象內(nèi)容的改變,注意監(jiān)聽數(shù)組的變動不需要這么做。注意:deep 無法監(jiān)聽到數(shù)組的變動和對象的新增,參考 vue 數(shù)組變異,只有以響應(yīng)式的方式觸發(fā)才會被監(jiān)聽到。

watch 和 computed 的區(qū)別是:

相同點(diǎn):

兩者都是觀察頁面數(shù)據(jù)變化的。

不同點(diǎn):

  • computed 只有當(dāng)依賴的數(shù)據(jù)變化時才會計(jì)算, 會緩存數(shù)據(jù)。
  • watch 每次都需要執(zhí)行函數(shù)。watch 更適用于數(shù)據(jù)變化時的異步操作。

使用 參考官方文檔

computed 使用

類型:{ [key: string]: Function | { get: Function, set: Function } }

詳細(xì):

計(jì)算屬性將被混入到 Vue 實(shí)例中。所有 getter 和 setter 的 this 上下文自動地綁定為 Vue 實(shí)例。

注意如果你為一個計(jì)算屬性使用了箭頭函數(shù),則 this 不會指向這個組件的實(shí)例,不過你仍然可以將其實(shí)例作為函數(shù)的第一個參數(shù)來訪問。

computed: {
 aDouble: vm => vm.a * 2
}

計(jì)算屬性的結(jié)果會被緩存,除非依賴的響應(yīng)式 property 變化才會重新計(jì)算。注意,如果某個依賴 (比如非響應(yīng)式 property) 在該實(shí)例范疇之外,則計(jì)算屬性是不會被更新的。

示例:

var vm = new Vue({
 data: { a: 1 },
 computed: {
  // 僅讀取
  aDouble: function () {
   return this.a * 2
  },
  // 讀取和設(shè)置
  aPlus: {
   get: function () {
    return this.a + 1
   },
   set: function (v) {
    this.a = v - 1
   },
  },
 },
})
vm.aPlus // => 2
vm.aPlus = 3
vm.a // => 2
vm.aDouble // => 4

watch 使用 與 解釋

類型:{ [key: string]: string | Function | Object | Array }

詳細(xì):

一個對象,鍵是需要觀察的表達(dá)式,值是對應(yīng)回調(diào)函數(shù)。值也可以是方法名,或者包含選項(xiàng)的對象。Vue 實(shí)例將會在實(shí)例化時調(diào)用 $watch(),遍歷 watch 對象的每一個 property。

示例:

var vm = new Vue({
 data: {
  a: 1,
  b: 2,
  c: 3,
  d: 4,
  e: {
   f: {
    g: 5,
   },
  },
 },
 watch: {
  a: function (val, oldVal) {
   console.log('new: %s, old: %s', val, oldVal)
  },
  // 方法名
  b: 'someMethod',
  // 該回調(diào)會在任何被偵聽的對象的 property 改變時被調(diào)用,不論其被嵌套多深
  c: {
   handler: function (val, oldVal) {
    ;/_ ... _/
   }, // or handler:'方法名'
   deep: true,
  },
  // 該回調(diào)將會在偵聽開始之后被立即調(diào)用
  d: {
   handler: 'someMethod', // or handler: function(val, oldVal){}
   immediate: true,
  },
  // 你可以傳入回調(diào)數(shù)組,它們會被逐一調(diào)用
  e: [
   'handle1',
   function handle2(val, oldVal) {
    /* ... */
   },
   {
    handler: function handle3(val, oldVal) {
     /* ... */
    },
    /* ... */
   },
  ],
  // watch vm.e.f's value: {g: 5}
  'e.f': function (val, oldVal) {
   ;/_ ... _/
  },
 },
})
vm.a = 2 // => new: 2, old: 1

說明: 對應(yīng)上方的 a~e

a: 監(jiān)聽一個屬性,需要使用前后變化值時使用

b: 監(jiān)聽一個屬性,不會使用到改變前后的值,只為了執(zhí)行一些方法,可以使用字符串代替 字符串代表方法名

c: 在監(jiān)聽一個對象時,當(dāng)對象內(nèi)部的屬性被改變時,無法觸發(fā) watch,設(shè)置 deep 為 true 后,無論嵌套多深,只要屬性值被改變都會觸發(fā)監(jiān)聽。但這種方式開銷會較大,監(jiān)聽器會一層一層往下找,為每個屬性添加監(jiān)聽器。

如果我們只是監(jiān)聽對象的某個屬性改變時,可以這樣做:

  watch:{
  'user.name':{
   handler: 'method'
  }

 }

d: watch 是在監(jiān)聽屬性改變時才會觸發(fā),組件創(chuàng)建時可能不會執(zhí)行,因此我們可以設(shè)置 immediate: true,就會讓在組件創(chuàng)建后 watch 能夠立即執(zhí)行一次。就不用在 create 的時候去修改屬性啦。

handelr: 觸發(fā)監(jiān)聽執(zhí)行的方法(需要用到改變前后的值時,可換成函數(shù))

immediate: 監(jiān)聽開始之后被立即調(diào)用

e: 監(jiān)聽一個屬性,執(zhí)行多個函數(shù)包括回調(diào)等

注意,不應(yīng)該使用箭頭函數(shù)來定義 watcher 函數(shù) (例如 searchQuery: newValue => this.updateAutocomplete(newValue))。理由是箭頭函數(shù)綁定了父級作用域的上下文,所以 this 將不會按照期望指向 Vue 實(shí)例,this.updateAutocomplete 將是 undefined。

總結(jié)

到此這篇關(guān)于vue中watch和computed的區(qū)別與使用方法的文章就介紹到這了,更多相關(guān)vue watch和computed的區(qū)別內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 基于Vue2實(shí)現(xiàn)數(shù)字縱向滾動效果

    基于Vue2實(shí)現(xiàn)數(shù)字縱向滾動效果

    這篇文章主要為大家詳細(xì)介紹了如何基于Vue2實(shí)現(xiàn)數(shù)字縱向滾動效果,從而達(dá)到顯示計(jì)時器滾動效果,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-03-03
  • Vue2.0使用過程常見的一些問題總結(jié)學(xué)習(xí)

    Vue2.0使用過程常見的一些問題總結(jié)學(xué)習(xí)

    本篇文章主要介紹了Vue2.0使用過程常見的一些問題總結(jié)學(xué)習(xí),詳細(xì)的介紹了使用中會遇到的各種錯誤,有興趣的可以了解一下。
    2017-04-04
  • Vue.js搭建移動端購物車界面

    Vue.js搭建移動端購物車界面

    這篇文章主要為大家詳細(xì)介紹了Vue.js搭建移動端購物車界面,重點(diǎn)介紹基本結(jié)構(gòu)和數(shù)據(jù)渲染,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • Vue跨端渲染實(shí)現(xiàn)多端無縫銜接

    Vue跨端渲染實(shí)現(xiàn)多端無縫銜接

    這篇文章主要介紹了Vue跨端渲染實(shí)現(xiàn)多端無縫銜接,Vue跨端渲染是一種基于Vue框架的跨平臺開發(fā)技術(shù),能夠?qū)崿F(xiàn)Web、iOS和Android三端的無縫銜接,提高開發(fā)效率和用戶體驗(yàn)
    2023-05-05
  • vue3使用reactive賦值后頁面不改變

    vue3使用reactive賦值后頁面不改變

    本文主要介紹了vue3使用reactive賦值后頁面不改變,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04
  • 解決vue熱替換失效的根本原因

    解決vue熱替換失效的根本原因

    今天小編就為大家分享一篇解決vue熱替換失效的根本原因,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • 關(guān)于Vue中使用alibaba的iconfont矢量圖標(biāo)的問題

    關(guān)于Vue中使用alibaba的iconfont矢量圖標(biāo)的問題

    這篇文章主要介紹了Vue使用alibaba的iconfont矢量圖標(biāo)的問題,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-12-12
  • vue 更改連接后臺的api示例

    vue 更改連接后臺的api示例

    今天小編就為大家分享一篇vue 更改連接后臺的api示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • Vue可左右滑動按鈕組組件使用詳解

    Vue可左右滑動按鈕組組件使用詳解

    這篇文章主要為大家詳細(xì)介紹了基于Vue可左右滑動按鈕組組件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • 解決vue的touchStart事件及click事件沖突問題

    解決vue的touchStart事件及click事件沖突問題

    這篇文章主要介紹了解決vue的touchStart事件及click事件沖突問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07

最新評論