zoukankan      html  css  js  c++  java
  • computed、methods、watch

    • 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。
    

    computed

      computed称为计算属性,顾名思义,计算就要返回一个计算的结果,所以,当我们要处理大量的逻辑,但是最后要取得最后的结果的时候可以用computed。

     简单示例: 要求: 
    <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

      methods:是方法的意思,在js中,我们把一些函数叫做方法,一般情况下,要触发这个方法就要执行,要执行就要有一个源来触发,所以就需要一个事件源,这是和computed的一点不同之处。

    methods的示例:要求:
    <button @click="do()">点击弹出</button>
    <script>
        new Vue({
            el:"#box",
            data:{
                    num1:0,
                    num2:0
                    }
            methods:{    
                    do:function(){
                          alert('ok')
                          //这里根据情况,可以返回有返回值也可以没有返回值。
                    }
            }
         })
    </script>

    对比computed 和 methods

    • computed计算的结果如果不发生改变就不会触发result这个函数。而methods中一般都是定义的需要事件触发的一些函数。每次只要触发事件,就会执行对应的方法。
    • computed必须返回一个值页面绑定的才能取得值,而methods中可以只执行逻辑代码,可以有返回值,也可以没有。
    • 如果把computed中的方法写到method中会浪费性能。
    <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('')  
        }  
      } 
    }) 
    • 计算属性只有在它的相关依赖发生改变时才会重新取值。这就意味着只要 message 没有发生改变,多次访问 reversedMessage 计算属性会立即返回之前的计算结果,而不必再次执行函数。也就是说只要不是直接使用浏览器刷新页面,当我们改变数据、DOM操作等引起页面重新渲染时,计算属性会直接使用缓存,不会重新执行函数。适合那些计算量很大且改变频率很低的属性;
    • 如果使用methods,每次页面重新渲染时都会重新执行methods函数。
    • 写法上:computed计算属性的方式在用属性时不用加(),而methods方式在使用时要像方法一样去用,必须加().
  • 相关阅读:
    查缺补漏中~~
    The number of divisors(约数) about Humble Numbers
    Octorber 21st
    素数回文
    盐水的故事
    居然因为交换错了好几把。。。。,还有坑点是num1可以大于num2
    税收与补贴问题(洛谷1023)
    斐波拉契高精度(洛谷1255)
    高精度模板
    Codeforces#373 Div2
  • 原文地址:https://www.cnblogs.com/lmjZone/p/7739306.html
Copyright © 2011-2022 走看看