vue---计算属性,方法和侦听

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script src="js/vue.js" type="text/javascript" charset="utf-8"></script>
	</head>
	<body>
		<div id="app">
			{{fullName}}
			{{age}}
		</div>
		<script>
			var vm=new Vue({
				el:"#app",
				data:{
					firstName:'sun',
					lastName:'yiyi',
					fullName:'sunyiyi',//侦听器
					age:28
				},
				
				//1、计算属性computed---值是一个函数 
				//内置缓存机制,如果依赖的变量没发生改变的话,不会重新计算
				//计算属性的getter和setter
				computed:{
					fullName:{
						//初始化调用fullName 取值
						get:function(){
							return this.firstName+this.lastName
						},
						//set fullName 设置一个值时调用
						set:function(value){
							var arr=value.split(' ');
							this.firstName=arr[0]
							this.lastName=arr[1]
						}
					}
				},
				
				//2、方法methods也可实现计算属性功能 调用的时候是{{fullName()}}
				//相比于计算属性,无缓存机制存在
				methods:{
					fullName:function(){
						return this.firstName+this.lastName
				 	}
				},
				
				//3、侦听器watch---侦听firstName和lastName的变化
				//内置缓存机制,如果依赖的变量没发生改变的话,不会重新计算
				watch:{
					firstName:function(){
						this.fullName=this.firstName+this.lastName
					},
					lastName:function(){
						this.fullName=this.firstName+this.lastName
					}
				},
				
				//如果同一个功能computed,methods,watch都可以使用,优先使用computed
			})
		</script>
	</body>
</html>

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值