computed
computed是一种基于响应式依赖进行缓存的。示例:
<body>
<div id="app" v-bind:title="message">
<div>{{random2}}</div>
<div>{{random2}}</div>
<div>{{random()}}</div>
<div>{{random()}}</div>
</div>
<script type="text/javascript">
var app = new Vue({
"el":"#app",
computed:{
random2:function() {
return Math.random();
}
},
methods:{
random:function() {
return Math.random();
}
}
});
</script>
</body>
输出:
0.9472651306992299
0.9472651306992299
0.895105211141914
0.2601213679321581
从结果可以看出,计算属性里的random2在第二次调用的时候,会返回之前的结果。而methods里的random方法在调用的时候,都会返回新的值。那么computed的random2在什么情况下会返回新的值呢?答案就是当修改random2里prefix值的时候,会再一次计算。示例:
<body>
<div id="app">
</div>
<script type="text/javascript">
var app = new Vue({
"el":"#app",
data:{
prefix:"time="
},
computed:{
random2:function() {
return this.prefix + Math.random();
}
},
methods:{
random:function() {
return this.prefix + Math.random();
}
}
});
console.log(app.random2);
console.log(app.random2)
console.log(app.random());
console.log(app.random());
console.log("-----------");
app.prefix = "time:";
console.log(app.random2);
console.log(app.random2)
console.log(app.random());
console.log(app.random());
</script>
</body>
控制台打印:
time=0.9769481348329911
time=0.9769481348329911
time=0.7013610338357816
time=0.7499808656103688
-----------
time:0.5400807277397943
time:0.5400807277397943
time:0.9306663423885653
time:0.22180188769312004
由此可以看出,当我们修改prefix值后,再次调用random2方法的时候,值发生了变化,但是第二次调用依旧会返回之前的值。