项目场景:

开发一个产品使用到比较复杂且独立的自定义组件,自定义组件是自定义复选框/单选框

问题描述:

用ref 注册子组件,父组件可以通过this.$refs.xx.fn调用子组件里的函数,但是有时会出现 undefined 未定义的情况。

vue代码

<view class="sg-checkbox">
	<helang-checkbox ref="checkbox" @change="onChange"></helang-checkbox>
</view>

js代码

this.$refs.checkbox.set({
	type:ctype,		// 类型:复选框
	column:column,	// 分列:2
	list:list_data	// 列表数据
});

原因分析:

vue 官网中ref 下有一段话 “关于 ref 注册时间的重要说明:因为 ref 本身是作为渲染结果被创建的,在初始渲染的时候你不能访问它们 - 它们还不存在!$refs 也不是响应式的,因此你不应该试图用它在模板中做数据绑定。”
意思就是需用ref之前,对于的组件必须先渲染成功,否则就不能使用ref


解决方案:

以下有三个方法可以解决这个问题

1、如果你在mounted里获取this. r e f s , 因 为 d o m 还 未 完 全 加 载 , 所 以 你 是 拿 不 到 的 , u p d a t e 阶 段 则 是 完 成 了 数 据 更 新 到 d o m 的 阶 段 ( 对 加 载 回 来 的 数 据 进 行 处 理 ) , 此 时 , 就 可 以 使 用 t h i s . refs,因为dom还未完全加载,所以你是拿不到的, update阶段则是完成了数据更新到 dom 的阶段(对加载回来的数据进行处理),此时,就可以使用this. refsdomupdatedom()使this.refs了

2、如果写在method中,那么可以使用 this.$nextTick(() => {}) 等页面渲染好再调用,这样就可以了

3、可以加个定时器延时加载this.$refs

this.$nextTick(()=>{
	this.$refs.checkbox.set({
		type:ctype,		// 类型:复选框
		column:column,	// 分列:2
		list:list_data	// 列表数据
	});
})
Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐