uni-app小程序父组件数据更新,实现自定义组件刷新视图

情景介绍

业务需求得做一个刷题单选框的组件,选中错误自动显示正确的。思路父组件监听题目的变化更新选项list,子组件深度监听proprs数据,变化的时候及时更新视图。但是发现一个问题,判断题的选项是一样的导致我渲染第一个题的时候无法操作下一题的选项,组件没有更新视图。

解决办法:将子组件深度监听里的逻辑封装成方法,由父组件每次更新数据的时候强心渲染子组件,解决选项list一样的时候深度监听不调用方法。

父组件

<selectOptions ref="options"  @ok="change"></selectOptions>

监听数据逻辑

this.$refs.options.updateOptions(this.optionList,this.answer,this.answerFlag);

子组件方法

之前错误的思路

watch:{
	optionList: {
			deep: true,  // 需要深度监听
			handler(newValue,oldValue){
				// 更新数据
				this.u_answer = this.answerFlag;
				if(this.u_answer){
					this.checkanswer = ['/']; // 回显的特殊处理
				}else{
					this.checkanswer = [];
				}
				this.value = [];
				this.options = newValue;
			}
		},
				
},

新思路(忽略我的参数命名,写文章的时候方便。)

// 更新数据
	updateOptions(d,a,f){
		console.log("刷新")
		// 更新数据
		this.u_answer = f;
		if(a){
			this.checkanswer = ['/']; // 回显的特殊处理
		}else{
			this.checkanswer = [];
		}
		this.value = [];
		this.options = d;
	},

最后完美解决问题

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值