computed、methods、watch

2017-09-27  本文已影响0人  陆lmj

computed:计算属性将被混入到 Vue 实例中。所有 getter 和 setter 的 this 上下文自动地绑定为 Vue 实例。
methods:methods 将被混入到 Vue 实例中。可以直接通过 VM 实例访问这些方法,或者在指令表达式中使用。方法中的 this 自动绑定为 Vue 实例。
watch:是一种更通用的方式来观察和响应 Vue 实例上的数据变动。一个对象,键是需要观察的表达式,值是对应回调函数。值也可以是方法名,或者包含选项的对象。Vue 实例将会在实例化时调用 $watch(),遍历 watch 对象的每一个属性。

通俗来讲,
1. computed是在HTML DOM加载后马上执行的,如赋值;
2. methods则必须要有一定的触发条件才能执行,如点击事件;
3. watch它用于观察Vue实例上的数据变动。对应一个对象,键是观察表达式,值是对应回调。值也可以是方法名,或者是对象,包含选项。
所以他们的执行顺序为:默认加载的时候先computed再watch,不执行methods;等触发某一事件后,则是:先methods再watch。
 简单示例: 要求: <input type="text v-model="num1"><input type="text v-model="num2"> 
   现在要返回num1和num2的和; <script>
    new Vue({
        el:"#box",
        data:{
                num1:0,
                num2:0
                }
        computed:{    
                result:function(){
                        return this.num1 + this.num2    
                        // 计算属性必须有一个返回值
                }
        }
     })
</script>
methods的示例:
要求:
<button @click="do()">点击弹出<\/button>
<script>
    new Vue({
        el:"#box",
        data:{
                num1:0,
                num2:0
                }
        methods:{    
                do:function(){
                      alert('ok')
                      //这里根据情况,可以返回有返回值也可以没有返回值。
                }
        }
     })
</script>

对比computed 和 methods

<div id="example">  
  <p>Original message: "{{ message }}"</p>  
  <p>Computed reversed message: "{{ reversedMessage }}"</p>  
</div>

var vm = new Vue({  
  el: '#example',  
  data: {  
    message: 'Hello'  
  },  
  computed: {  
    reversedMessage: function () {  
      return this.message.split('').reverse().join('')  
    }  
  },
  methods: {  
    reverseMessage: function () {  
      return this.message.split('').reverse().join('')  
    }  
  } 
}) 
上一篇 下一篇

猜你喜欢

热点阅读