[Vue.js]学习笔记-Vue.js计算属性-computed setter
导读部分
教程部分
Vue.js 使用了基于 HTML 的模版语法,允许开发者声明式地将 DOM 绑定至底层 Vue 实例的数据。 另: Vue.js 的核心是一个允许你采用简洁的模板语法来声明式的将数据渲染进 DOM 的系统。
Vue.js 计算属性关键词: computed。 计算属性在处理一些复杂逻辑时是很有用, 主要使模板变的简单易懂,计算方法均在js中处理。 computed 属性默认只有 getter ,不过在需要时你也可以提供一个 setter, 看内容的直观意思就是, getter是获取值的, 而setter是修改值内容的
下面我们通过实例来进行computed的getter与setter的使用方法: 实例:
[HTML] 纯文本查看 复制代码 <!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Vue 测试实例 - 苏飞论坛(sufeinet.com)</title>
<script src="https://cdn.staticfile.org/vue/2.4.2/vue.min.js"></script>
</head>
<body>
<div id="app">
<p>{{ site }}</p>
</div>
<script>
var vm = new Vue({
el: '#app',
data: {
name: 'Google',
url: 'http://www.google.com'
},
computed: {
site: {
// getter
get: function () {
return this.name + ' ' + this.url
},
// setter
set: function (newValue) {
var names = newValue.split(' ')
this.name = names[0]
this.url = names[names.length - 1]
}
}
}
})
// 调用 setter, vm.name 和 vm.url 也会被对应更新
vm.site = '苏飞论坛 [url]http://www.sufeinet.com[/url]';
document.write('name: ' + vm.name);
document.write('<br>');
document.write('url: ' + vm.url);
</script>
</body>
</html>
运行结果如下:
通过上例可以看到, setter会修改原有的内容, 并将修改后的内容输出
|