5、计算属性computed

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方法的时候,值发生了变化,但是第二次调用依旧会返回之前的值。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值