iT邦幫忙

第 11 屆 iThome 鐵人賽

DAY 12
1
自我挑戰組

前端新手筆記-Vue.js系列 第 12

Day12 Vue computed VS watch VS method

本文同步發表於Andy's Blog

前言

這兩天我們介紹完了Computed與watch特性與用法。那今天我們將來了解一下,這三者有什麼差異。

第一部分:computed VS watch

OK,我們首先簡單複習一下,這兩者的特性。
Computed:適合用來處理複雜邏輯運算。
Watch:會去監聽特定變數,當變數產生變動時,就會執行某個動作。
範例:
HTML部分

    <div id="app">
    {{ fullName }}
    <br>
    <input type="text" v-model="firstName">
    <br>
    <input type="text" v-model="lastName">
  </div>

JavaScript寫法一(使用Watch)

var vm = new Vue({
      el: '#app',
      data: {
        firstName: 'chunwen',
        lastName: 'YU',
        // 我們需要手動設定初始值
        fullName: 'chunwen YU'
      },
      watch: {
        // 參數可以自行命名(更新資料,原始資料)
        firstName: function (newValue,rawValue) {
          // console.log('資料:',newVal,rawValue)
          this.fullName = `${newValue} ${this.lastName}`
          console.log(this.fullName)
        },
        lastName: function (newValue) {
          this.fullName = `${this.firstName} ${newValue}`
        },
      },
    });

JavaScript寫法二(使用Computed)

var vm = new Vue({
      el: '#app',
      data: {
        firstName: 'chunwen',
        lastName: 'YU',
      },
      computed:{
        fullName(){
           return `${this.firstName} ${this.lastName}`
        }
      }
    });

小總結

1.我們可以發現使用Computed寫法時,並不需要在data預先定義好fullName的資料初始值
2.相對watch而言,computed寫法更為簡便

使用時機

1.watch適合用來觀察資料變動
2.如果你的某個變數是依賴其他變數⽽來(如範例:fullName會觀察firstName與LastName),這時候就適合使用computed


第二部分 computed VS methods()差異

開始前,簡單複習一下methods()特性
會與v-on一起使用:主要目的:用來定義內部資料使用的函式方法
範例: 練習連結
HTML部分

<div id="app">
    <input type="text" v-model="message">
    <div>reversedMessage: {{ reversedMessage }}</div>
    <div>reversedMessage: {{ reversedMessage }}</div>
    <div>reversedMessage: {{ reversedMessage }}</div>
   
    <hr>
    <div>reversedMessage_method(): {{ reversedMessage_method() }}</div>
    <div>reversedMessage_method(): {{ reversedMessage_method() }}</div>
    <div>reversedMessage_method(): {{ reversedMessage_method() }}</div>
  </div>

JavaScript部分

 var vm = new Vue({
      el: '#app',
      data: {
        message: 'Hello 5xRuby!'
      },
      methods: {
        reversedMessage_method:function() {
          console.log('methods');
          return this.message.split('').reverse().join('');
        }
      },
      computed: {
        reversedMessage: function () {
          console.log('computed');
          return this.message.split('').reverse().join('');
        }
      }
    });

執行結果如下

小結論

我們從圖片中觀看這兩者運行結果,的確一樣。但是,我們打開console.log後,就可以發現只要資料一進行跟動methods()就會執行一次,但computed卻不會。這也就是為何我們要HTML要寫三次的原因(Kuro老師說重要的事情要講三次XD)

1.computed會將data中的資料進行cache緩存,當資料變動時候再一起更動
2.Method則會在data改變時候,直接進行更動。缺點:需要耗費較高效能

總結:methods、computed、watch使用時機

1.methods: 這是需要主動觸發,且可以多次重複觸發
2.Computed: 當資料需要複雜運算時
3.Watch: 監控特定資料變化的 function 就放這裡

參考資料

1.用範例理解 Vue.js #6:Computed vs Methods
2.計算屬性緩存vs 方法


上一篇
Day11 Vue Watch介紹
下一篇
Day 13 Vue Filter 過濾器介紹
系列文
前端新手筆記-Vue.js30
圖片
  直播研討會
圖片
{{ item.channelVendor }} {{ item.webinarstarted }} |
{{ formatDate(item.duration) }}
直播中

1 則留言

0
kkdayy_55330
iT邦新手 5 級 ‧ 2020-02-01 17:31:17

嗨大大您好,

這部分寫錯了喔:

我們從圖片中觀看這兩者運行結果,的確一樣。但是,我們打開console.log後,就可以發現只要資料一進行跟動methods()就會執行一次,但computed卻不會。

methods 和 computed 在 console.log 運行結果並不是像你所說的那樣~

chunwen iT邦新手 4 級 ‧ 2020-02-01 23:22:19 檢舉

hello 您好
不太懂您說的
methods 和 computed 在 console.log 運行結果並不是像你所說的那樣~ 是指什麼意思?

我要留言

立即登入留言