美文网首页
Vue学习笔记[03]-计算属性和方法

Vue学习笔记[03]-计算属性和方法

作者: 神楽花菜 | 来源:发表于2019-10-10 18:45 被阅读0次

    什么是vue的方法

    vue的方法和之前的el,data一样,是vue实例的options参数,可以随vue的实例构造传入.下面是两个例子介绍了methods的基本用法:

    <!--未使用methods的例子-->
    <body>
      <div id="app">
        <button @click='counter++'>click  me {{counter}} times!</button>
    
      </div>
    </body>
    <script>
    let vm = new Vue({
      el:'#app',
      data:{
        counter:0,
      }
    })
    </script>
    

    在上一个例子中,我们没有使用methodsoptions,因为我们的事件处理足够简单,基于vue的响应式,我们可以动态的改变button标签中的counter变量的值.可是一旦事件处理的函数十分冗长,我们就不适合在html标签中写入方法.还好methods可以拯救我们:

    <body>
      <div id="app">
        <button @click='addCounter()'>click  me {{counter}} times!</button>
    
      </div>
    </body>
    <script>
    let vm = new Vue({
      el:'#app',
      data:{
        counter:0,
      },
      methods:{
        addCounter:function(){
          this.counter++;
        }
      }
      
    })
    </script>
    

    这里的methods中封装了让counter增加的方法,效果和之前的一样.

    有时,我们需要对html中呈现的内容做一些处理,例如把姓和名连接在一起,我们可以这样做

    <body>
      <div id="app">
       <li>name:{{firstname}} {{lastname}}</li> 
      </div>
    </body>
    <script>
      let vm = new Vue({
        el: '#app',
        data: {
          firstname: 'Sam',
          lastname: 'Smith',
        },
      })
    </script>`
    

    也可以借助方法来实现

    <body>
      <div id="app">
       <li>name:{{firstname}} {{lastname}}</li> 
      </div>
    </body>
    <script>
      let vm = new Vue({
        el: '#app',
        data: {
          firstname: 'Sam',
          lastname: 'Smith',
        },
           methods:{
          getFullName:function(){
            return this.firstname + ' ' + this.lastname;
          }
        }
      })
    </script>`
    
    

    另一种方法使用 计算属性(computed) 来实现.

    计算属性

    计算属性也是一种vue的options,其中一般定义一些需要格式化或者处理的属性.

    <html>
    <script src="https://cn.vuejs.org/js/vue.js"></script>
    
    <body>
      <div id="app">
        <li>name:{{firstname}} {{lastname}}</li>
        <li>Name:{{getFullName()}}</li>
        <li>Name:{{fullName}}</li>
      </div>
    </body>
    <script>
      let vm = new Vue({
        el: '#app',
        data: {
          firstname: 'Sam',
          lastname: 'Smith',
        },
        methods: {
          getFullName: function () {
            return this.firstname + ' ' + this.lastname;
          }
        },
        computed: {
          fullName: function () {
            return this.firstname + ' ' + this.lastname;
          }
        }
      })
    </script>
    </html>
    

    那么,methodscomputed有什么区别呢?

    首先,computed中更加偏向于同firstnamelastname一样作为属性存在,在使用时也不需要加()在阅读时更加统一.

    其次,计算属性是有一定缓存的,这意味着在使用计算属性时,若属性的值未发生变化,只需调用一次计算属性的方法.而在methods中定义的方法没有缓存,无论值是否改变,都需要多次调用.来看下面的例子:

    <body>
      <div id="app">
        <li>Name:{{getFullName()}}</li>
        <li>Name:{{getFullName()}}</li>
        <li>Name:{{getFullName()}}</li>
        <li>Name:{{getFullName()}}</li>
        <li>Name:{{getFullName()}}</li>
    
      </div>
    </body>
    <script>
      let vm = new Vue({
        el: '#app',
        data: {
          firstname: 'Sam',
          lastname: 'Smith',
        },
        methods: {
          getFullName: function () {
            console.log('被调用');
            return this.firstname + ' ' + this.lastname;
          }
        },
        
      })
    </script>
    
    image
    <body>
      <div id="app">
          <li>Name:{{fullName}}</li>
          <li>Name:{{fullName}}</li>
          <li>Name:{{fullName}}</li>
          <li>Name:{{fullName}}</li>
          <li>Name:{{fullName}}</li>
      </div>
    </body>
    <script>
      let vm = new Vue({
        el: '#app',
        data: {
          firstname: 'Sam',
          lastname: 'Smith',
        },
        computed: {
          fullName: function () {
            console.log('被调用');
            return this.firstname + ' ' + this.lastname;
          }
        },
        
      })
    </script>
    
    </html>
    
    
    image

    因为计算属性的值未发生变化,所以计算属性的方法只被调用了一次.通过在控制台输入vm.firstname = 'OtherName'后可发现计算属性的方法又被调用了.同时HTML中显示的内容仍然被响应式的修改.

    相关文章

      网友评论

          本文标题:Vue学习笔记[03]-计算属性和方法

          本文链接:https://www.haomeiwen.com/subject/qwnupctx.html