您的位置:首页 > Web前端 > Vue.js

vue.js使用之计算属性与方法返回的差别

2017-08-20 14:34 891 查看
<!DOCTYPE html>
<html>
<head>
<script src="https://unpkg.com/vue@2.4.2"></script>
<meta charset="utf-8" />
<title></title>
</head>
<body>
<div id="app-6">
<p v-once v-if="see">{{ message }}</p>
<p   v-if="see">{{ reversedMessage  }}</p>
<p v-if="see">{{ reversedMessages()  }}</p>

<input  v-model="message">
<ol>

<todo-item
v-for="item in groceryList"
v-bind:todo="item"
v-bind:key="item.id"
></todo-item>

</ol>
</div>
</body>
</html>

<script>
var app6;
window.onload = function () {

Vue.component('todo-item', {
template: '<li>{{todo.text}}</li>',
props:['todo']
})
app6 = new Vue({
el: '#app-6',
data: {
see: true,
groceryList: [
{ id: 0, text: '蔬菜' },
{ id: 1, text: '奶酪' },
{ id: 2, text: '随便其他什么人吃的东西' }
],

message: 'Hello Vue!'
},
//计算属性 computed: { reversedMessage: function () { return this.message.split('').reverse().join('') } },
//方法返回 methods: { reversedMessages: function () { return this.message.split('').reverse().join('') } } }) } </script>

  注意 由于计算属性与method 与data中的属性都是保存在app6这个对象的一级属性里面 所以如果重名 后定义的将会覆盖前定义的对象

官方文档解释两者的差别

我们可以将同一函数定义为一个 method 而不是一个计算属性。对于最终的结果,两种方式确实是相同的。然而,不同的是计算属性是基于它们的依赖进行缓存的。计算属性只有在它的相关依赖发生改变时才会重新求值。这就意味着只要 

message
 还没有发生改变,多次访问 
reversedMessage
 计算属性会立即返回之前的计算结果,而不必再次执行函数。

这也同样意味着下面的计算属性将不再更新,因为 

Date.now()
 不是响应式依赖:

computed: { now: function () { return Date.now() } }

相比而言,只要发生重新渲染,method 调用总会执行该函数。

文档地址 https://cn.vuejs.org/v2/guide/computed.html

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: