码迷,mamicode.com
首页 > 其他好文 > 详细

vue实例属性之methods和computed

时间:2017-10-13 20:22:19      阅读:175      评论:0      收藏:0      [点我收藏+]

标签:rom   计算   code   fun   style   它的   blog   -o   reverse   

我们可以把同一函数放在methods或者computed中,区别在于computed有缓存,计算属性只有在它的相关依赖发生改变时才会重新求值,即数据改变才会执行函数。而methods每当触发重新渲染时,就会再次执行函数。

一、methods用法

<div id="J_app">
  <p>{{ info }}</p>
  <button v-on:click="reverseText">逆转消息</button>
  <button @click="reverseText">v-on缩写,逆转消息</button>
</div>
var vapp = new Vue({
  el: ‘#J_app‘,
  data: {
    info: ‘Hello Vue.js!‘
  },
  methods: {
    reverseText: function () {
      this.info = this.info.split(‘‘).reverse().join(‘‘)
    }
  }
})

二、computed用法

1、默认用法

<div id="J_app">
  <p>{{ info }}</p>
  <p>{{ reverseText }}</p>
</div>
var vapp = new Vue({
  el: ‘#J_app‘,
  data: {
    info: ‘Hello Vue.js!‘
  },
  computed: {
    reverseText: function () {
      return this.info.split(‘‘).reverse().join(‘‘)
    }
  }
})

2、自定义set
computed默认只有get,可以自定义一个set。

<div id="J_app">
  <p>{{ info }}</p>
  <p>{{ reverseText }}</p>
</div>
var vapp = new Vue({
  el: ‘#J_app‘,
  data: {
    info: ‘Hello Vue.js!‘
  },
  computed: {
    reverseText: {
        get:function () {
          return this.info.split(‘‘).reverse().join(‘‘)
        },
        set:function () {
          this.info = this.info.split(‘‘).reverse().join(‘‘) +‘设置后‘
        }
    }
  }
})
vapp.reverseText ="learn vue from today";

 

vue实例属性之methods和computed

标签:rom   计算   code   fun   style   它的   blog   -o   reverse   

原文地址:http://www.cnblogs.com/camille666/p/vue_instance_prop_methods_computed.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!