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

Vue 计算属性(四)

时间:2020-03-24 19:06:24      阅读:61      评论:0      收藏:0      [点我收藏+]

标签:一个   default   export   col   compute   性能   tps   参考   ref   

1、computed 选项:

<template>
  <div id="app">
      {{ reversedText }}
  </div>
</template>
<script>
export default {
  name: "App",
  data() {
    return {
      text: ‘123,456‘
    };
  },
  computed: {
    reversedText: function() {
      // 这里的 this 指向的是当前 Vue 实例
      return this.text.split(‘,‘).reverse().join(‘,‘);
    }
  }
  
};
</script>

2、methods 选项:

<template>
  <div id="app">
      <!-- 注意,这里的 reversedText 是方法,所以要带() -->
      {{ reversedText() }}
  </div>
</template>
<script>
export default {
  name: "App",
  data() {
    return {
      text: ‘123,456‘
    };
  },
  methods: {
    reversedText: function() {
      // 这里的 this 指向的是当前 Vue 实例
      return this.text.split(‘,‘).reverse().join(‘,‘);
    }
  }
  
};
</script>

3、可以发现methods里的方法与计算属性两种方式最终执行结果是完全相同的。然而,不同的是计算属性是基于它的依赖进行缓存的。一个计算属性所依赖的数据发生变化时,它才会重新取值。这就意味着只要 text 还没有发生改变,多次访问 reversedText 计算属性会立即返回之前的计算结果,而不必再次执行函数。

4、使用计算属性还是 methods 取决于你是否需要缓存,出于性能考虑,当遍历大数组和做大量计算时,应当使用计算属性。

 

 

参考:

《Vue.js 实战》

https://cn.vuejs.org/v2/guide/

 

Vue 计算属性(四)

标签:一个   default   export   col   compute   性能   tps   参考   ref   

原文地址:https://www.cnblogs.com/d0usr/p/12560693.html

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