提示
本文主要讲解 Vue 中的计算属性。@ermo
# 计算属性
计算属性的关键词是 computed
,用于数据的简单计算,避免模板因为冗余的计算公式而变得臃肿。
<div id="app">
<p>{{ message.split('').reverse().join('') }}</p>
</div>
上面这个例子需要将 message
进行加工,可以通过表达式实现。
也可以通过计算属性实现。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<script src="https://cdn.jsdelivr.net/npm/vue@2.7.14"></script>
</head>
<body>
<div id="app">
<p>{{ message.split('').reverse().join('') }}</p>
<p>原消息:{{message}}</p>
<p>翻转后的消息:{{reverseMsg}}</p>
</div>
<script>
var vm = new Vue({
el: '#app',
data: {
message: 'ermo.cc'
},
computed: {
reverseMsg: function() {
return this.message.split('').reverse().join('')
}
}
});
</script>
</body>
</html>
通过方法功能也可以实现对数据的加工。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<script src="https://cdn.jsdelivr.net/npm/vue@2.7.14"></script>
</head>
<body>
<div id="app">
<p>{{ reverseMsg() }}</p>
</div>
<script>
var vm = new Vue({
el: '#app',
data: {
message: 'ermo.cc'
},
methods: {
reverseMsg: function() {
return this.message.split('').reverse().join('');
}
}
});
</script>
</body>
</html>
计算属性 computed
与 methods
的区别是前者有缓存,在大量数据加工的情况下,只有相关响应式依赖发生改变才会重新求值。
computed: {
now: function() {
return Date.now();
}
}
上例中计算属性值 now
不依赖绑定数据,所以不会发生改变。
# set 方法
计算属性默认有提供 get 方法,如果需要用到 set 方法,可以进行自定义。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<script src="https://cdn.jsdelivr.net/npm/vue@2.7.14"></script>
</head>
<body>
<script>
var vm = new Vue({
el: '#app',
data: {
name: 'Google',
url: 'https://google.com'
},
computed: {
site: {
get: function() {
return this.name + ' ' + this.url;
},
set: function(newValue) {
var arr = newValue.split(' ');
this.name = arr[0];
this.url = arr[arr.length - 1];
}
}
}
});
vm.site = '二默 https://ermocc';
document.write('网站名:' + vm.name);
document.write('<br/>')
document.write('网站地址:' + vm.url);
</script>
</body>
</html>