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

vue.js入門教程之計(jì)算屬性

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

前言

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

模板中表達(dá)式非常便利,但是它們實(shí)際上只用于簡(jiǎn)單的操作。

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

這就是為什么 Vue.js 將綁定表達(dá)式限制為一個(gè)表達(dá)式,

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

來(lái)看這一個(gè)簡(jiǎn)單的例子

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

var vm = new Vue({ //之所以起名vm,是因?yàn)檫@其實(shí)是mvvm中的vm
 el: '#example',
 data: {
 a: 1
 },
 computed: {
 // 一個(gè)計(jì)算屬性的 getter
 b: function () {
  // `this` 指向 vm 實(shí)例
  return this.a + 1
 }
 }
})

輸出結(jié)果:

a=1,b=2

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

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

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

如果你想觀察 Vue 實(shí)例上的數(shù)據(jù)變動(dòng),可以使用Vue.js 提供的一個(gè)方法 $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實(shí)現(xiàn):

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

這樣寫是不是更簡(jiǎn)單,沒有多余的重復(fù)代碼,官方也鼓勵(lì)使用computed方法。

上面講computed時(shí),有提到該方法提供了默認(rèn)的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'時(shí),setter 就會(huì)被調(diào)用。vm.firstNamevm.lastName也會(huì)有相應(yīng)更新。這個(gè)方法,在有些時(shí)候是很有用的。

總結(jié)

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

相關(guān)文章

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

    vue實(shí)現(xiàn)簡(jiǎn)單放大鏡效果

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

    Vue3中簡(jiǎn)單實(shí)現(xiàn)動(dòng)態(tài)添加路由

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

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

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

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

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

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

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

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

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

    nodejs讀取并去重excel文件

    給大家?guī)?lái)一篇關(guān)于用nodejs實(shí)現(xiàn)excel文件的讀取并去重的功能,有興趣的朋友參考學(xué)習(xí)下。
    2018-04-04
  • VUE 文字轉(zhuǎn)語(yǔ)音播放的實(shí)現(xiàn)示例

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

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

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

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

    3種vue組件的書寫形式

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

最新評(píng)論