Vue.JS入門篇--計算屬性

jopen 8年前發布 | 48K 次閱讀 JavaScript開發

Vue.js 的內聯表達式非常方便,但它最合適的使用場景是簡單的布爾操作或字符串拼接。如果涉及更復雜的邏輯,你應該使用計算屬性

計算屬性是用來聲明式的描述一個值依賴了其它的值。當你在模板里把數據綁定到一個計算屬性上時,Vue 會在其依賴的任何值導致該計算屬性改變時更新 DOM。這個功能非常強大,它可以讓你的代碼更加聲明式、數據驅動并且易于維護。

通常情況下,使用計算屬性會比使用過程式的$watch回調更合適。比如下面的例子:

<div id="demo">{{fullName}}</div>
var vm = new Vue({
  data: {
    firstName: 'Foo',
    lastName: 'Bar',
    fullName: 'Foo Bar'
  }
})

vm.$watch('firstName', function (val) {
  this.fullName = val + ' ' + this.lastName
})

vm.$watch('lastName', function (val) {
  this.fullName = this.firstName + ' ' + val
})

上面的代碼是過程式的,并且比較笨重。對比一下計算屬性的版本:

    var vm = new Vue({
        el:'#demo',
        data: {
            firstName: 'Foo',
            lastName: 'Bar'
        },
        computed: {
            fullName: function () {
                return this.firstName + ' ' + this.lastName
            }
        }
    })

是不是感覺好多了?另外,你還可以為計算屬性提供一個 setter:

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]
    }
  }
}

計算屬性緩存
在 0.12.8 之前,計算屬性僅僅體現為一個取值的行為 —— 每次你訪問它的時候,getter 都會重新求值。在 0.12.8 中對此做了改進 —— 計算屬性的值會被緩存,只有在其某個反應依賴改變才會重新計算。

設想我們有一個開銷很大的計算屬性 A,它需要循環一個大數組并且完成很多運算。并且我們還有一個依賴 A 的計算屬性。如果沒有緩存,我們對 A 的 getter 不必要的過度調用就會導致潛在的性能問題。而有了緩存,A 的值會被緩存起來,除非其依賴發生了變化,這樣訪問它再多次也不會導致大量的不必要運算了。

然而,我們還是應該理解什么會被視為“反應式依賴”:

var vm = new Vue({
  data: {
    msg: 'hi'
  },
  computed: {
    example: {
      return Date.now() + this.msg
    }
  }
})

在上面的例子中,計算屬性依賴 vm.msg。因為這是一個在 Vue 實例中被觀察的數據屬性,那么它就被視為了一個反應式依賴。無論何時 vm.msg 改變,vm.example 的值都會被重新計算。
然而,Date.now()并不是反應式依賴,因為它沒有和 Vue 的數據觀察系統發生任何關系。因此,當你在程序中訪問vm.example時,你會發現除非vm.msg觸發了一次重新計算,否則時間戳始終是相同的值。

有的時候你需要保留簡單獲取數據的模式,每次你訪問 vm.example 的時候都希望觸發重新計算。從 0.12.11 開始,你可以為一個特殊的計算屬性開關緩存支持:

computed: {
  example: {
    cache: false,
    get: function () {
      return Date.now() + this.msg
    }
  }
}

現在,每次你訪問 vm.example 的時候,時間戳都會及時更新。然而,要注意這只發生在 JavaScript 程序內部訪問的時候,數據綁定還是依賴驅動的。當你在模板中綁定一個 {{example}} 的計算屬性時,DOM 只會在反應式依賴改變時才會更新。

來自: http://www.jianshu.com/p/1be3ef82a55b

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!