解决watch监听复杂数据类型中新值老值相同问题

这是Vue2.0版本的问题,与程序员们无关

我们可以用到Json数据类型转换来解决这个问题

代码如下:

                <div id="app">
					<p>FullName: {{person.fullname}}</p>
					<p>FirstName: <input type="text" v-model="person.firstname"></p>
				</div>
				
				<script src="vue.js"></script>
				<script>
					const app = new Vue({
						el: "#app",
						data() {
							return {
								person: {
									firstname: 'Menghui',
									lastname: 'Jin',
									fullname: ''
								}
							}
						},
						methods: {
		
						},
						computed: {
							person2() {
								return JSON.parse(JSON.stringify(this.person));
							} //解决深度监听新老值相同问题
						},
						watch: {
							person2: {
								handler(n, o) {
									console.log(this.person);
									console.log(n.firstname);
									console.log(o.firstname);
		
									/* this.person.fullname = this.person.firstname + this.person.lastname */
								},
								/* immediate: true, */
								deep: true // 可以深度检测到 person 对象的属性值的变化
							}
						}
					})
				</script>

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值