1.计算属性设计的初衷是为了减轻模板上的业务负担。当数据链上出现复杂的衍生数据时,我们更期望以一种简单易维护的方式去使用它。它使代码结构更加清晰。
2.计算属性是依赖于响应式数据的,当响应式数据变化时,计算属性才会被重新计算,并且结果会被缓存,直到响应式数据再次变化。相比于使用methods函数求值,显得更加高效。
看如下一段程序:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<script src="https://cdn.jsdelivr.net/npm/vue@2.5.16/dist/vue.min.js"></script>
<title>Document</title>
</head>
<body>
<div id="app">
<span>{{message}}</span>
<span>{{megrev}}</span>
<button @click="toggle">点我</button>
</div>
<script>
let vm=new Vue({
el:'#app',
data() {
return {
message:'abcdefg'
}
},
computed: {
megrev(){
console.log(this.message);
return this.message.split('').reverse().join('');
}
},
methods: {
toggle(){
console.log(this.message);
this.message=this.message;
}
},
});
</script>
</body>
</html>
不断点击按钮后,控制台显示:
这证明了计算属性计算的值是会被缓存的,直到其所依赖的响应式数据发生变化时,才会被重新计算。