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

vue.js入門教程之計算屬性

 更新時間:2016年09月01日 16:38:23   作者:webCoder  
Vue.js 的內(nèi)聯(lián)表達式非常方便,但它最合適的使用場景是簡單的布爾操作或字符串拼接。如果涉及更復雜的邏輯,你應(yīng)該使用計算屬性。這篇文章我們將一起學習vue.js的計算屬性。什么是計算屬性,為什么要用這東西呢?通過下面這篇文章你將解決這些問題,下面來一起看看吧。

前言

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

模板中表達式非常便利,但是它們實際上只用于簡單的操作。

模板是為了描述視圖的結(jié)構(gòu),在模板中放入太多的邏輯會讓模板過重且難以維護。

這就是為什么 Vue.js 將綁定表達式限制為一個表達式,

如果需要多于一個表達式的邏輯,應(yīng)當使用計算屬性。

來看這一個簡單的例子

<div id="example">
 a={{ a }}, b={{ b }}
</div>

var vm = new Vue({ //之所以起名vm,是因為這其實是mvvm中的vm
 el: '#example',
 data: {
 a: 1
 },
 computed: {
 // 一個計算屬性的 getter
 b: function () {
  // `this` 指向 vm 實例
  return this.a + 1
 }
 }
})

輸出結(jié)果:

a=1,b=2

這里我們聲明了一個計算屬性 b。我們提供的函數(shù)將用作屬性 vm.b的 getter。

console.log(vm.b) // -> 2
vm.a = 3
console.log(vm.b) // -> 3

你可以像綁定普通屬性一樣在模板中綁定計算屬性。Vue 知道 vm.b 依賴于 vm.a,因此當 vm.a 發(fā)生改變時,依賴于 vm.b 的綁定也會更新。而且最妙的是我們是聲明式地創(chuàng)建這種依賴關(guān)系:計算屬性的 getter 是干凈無副作用的,因此也是易于測試和理解的。

如果你想觀察 Vue 實例上的數(shù)據(jù)變動,可以使用Vue.js 提供的一個方法 $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
})

不過上面的方法也可以使用computed實現(xiàn):

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

這樣寫是不是更簡單,沒有多余的重復代碼,官方也鼓勵使用computed方法。

上面講computed時,有提到該方法提供了默認的get方法,那么有沒有set方法呢?

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

如果我們調(diào)用 vm.fullName = 'John Doe'時,setter 就會被調(diào)用。vm.firstNamevm.lastName也會有相應(yīng)更新。這個方法,在有些時候是很有用的。

總結(jié)

以上就是關(guān)于vue.js計算屬性的全部內(nèi)容,希望這篇文章對大家能有所幫助,小編還會陸續(xù)更新關(guān)于vue.js的內(nèi)容,感興趣的小伙伴們可以繼續(xù)關(guān)注腳本之家。

相關(guān)文章

  • vue實現(xiàn)簡單放大鏡效果

    vue實現(xiàn)簡單放大鏡效果

    這篇文章主要為大家詳細介紹了vue實現(xiàn)簡單放大鏡效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • Vue3中簡單實現(xiàn)動態(tài)添加路由

    Vue3中簡單實現(xiàn)動態(tài)添加路由

    本文主要介紹了Vue3中簡單實現(xiàn)動態(tài)添加路由,,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-05-05
  • vue獲取時間戳轉(zhuǎn)換為日期格式代碼實例

    vue獲取時間戳轉(zhuǎn)換為日期格式代碼實例

    這篇文章主要介紹了vue獲取時間戳轉(zhuǎn)換為日期格式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-04-04
  • Vue+Koa2+mongoose寫一個像素繪板的實現(xiàn)方法

    Vue+Koa2+mongoose寫一個像素繪板的實現(xiàn)方法

    這篇文章主要介紹了Vue+Koa2+mongoose寫一個像素繪板的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-09-09
  • Vue中的匿名插槽與具名插槽詳解

    Vue中的匿名插槽與具名插槽詳解

    這篇文章主要為大家介紹了Vue中的匿名插槽與具名插槽,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-12-12
  • 淺析vue 函數(shù)配置項watch及函數(shù) $watch 源碼分享

    淺析vue 函數(shù)配置項watch及函數(shù) $watch 源碼分享

    這篇文章主要介紹了vue 函數(shù)配置項watch及函數(shù) $watch 源碼分享 ,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-11-11
  • nodejs讀取并去重excel文件

    nodejs讀取并去重excel文件

    給大家?guī)硪黄P(guān)于用nodejs實現(xiàn)excel文件的讀取并去重的功能,有興趣的朋友參考學習下。
    2018-04-04
  • VUE 文字轉(zhuǎn)語音播放的實現(xiàn)示例

    VUE 文字轉(zhuǎn)語音播放的實現(xiàn)示例

    本文主要介紹了VUE 文字轉(zhuǎn)語音播放的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • Vue動態(tài)樣式幾種常用方法總結(jié)

    Vue動態(tài)樣式幾種常用方法總結(jié)

    這篇文章主要給大家介紹了關(guān)于Vue動態(tài)樣式幾種常用方法總結(jié)的相關(guān)資料,在我們的前端界面中,很多的地方的樣式都是不確定的狀態(tài),要根據(jù)其他內(nèi)容的變化而變化樣式的,需要的朋友可以參考下
    2023-08-08
  • 3種vue組件的書寫形式

    3種vue組件的書寫形式

    這篇文章主要為大家詳細介紹了3種vue組件的書寫形式,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11

最新評論