vue--this.$refs.***.validate(() =>{}) undefined

vue与elementui中的form

标this.$refs.***.validate(() =>{}) undefined:未定义

用ref 注册子组件,父组件可以通过this.$refs.xx.fn调用子组件里的函数,但是有时会出现 fn 为定义的情况,这是为什么呢?

vue 官网中ref 下有一段话 “关于 ref 注册时间的重要说明:因为 ref 本身是作为渲染结果被创建的,在初始渲染的时候你不能访问它们 - 它们还不存在!$refs 也不是响应式的,所以你不应该试图用它在模板中做数据绑定。”

也就是说 ref 只有等页面加载完成好之后你才能调用 this. r e f s , 如 果 你 使 用 v − i f 、 v − f o r 渲 染 页 面 的 话 , 那 么 在 刚 开 始 页 面 没 没 渲 染 之 前 你 是 拿 不 到 t h i s . refs ,如果你使用v-if 、v-for渲染页面的话,那么在刚开始页面没没渲染之前你是拿不到this. refs使vifvforthis.refs 的,所以要等到页面渲染之后拿才可以

解决办法:

  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(这个方法还没有试)

转载: https://blog.csdn.net/changzhen11/article/details/84067816.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值
>