在vue中通过render函数给组件设置ref不生效

正常我们的写法是,这样ref不会生效,h是作用在渲染的时候的,而ref是渲染之后才创建的,因此在h函数中使用ref是无效的。
如下
在这里插入图片描述
在这里插入图片描述
这边打印出来的为undefined

render: (h, params) => {
return h(expandRow, {
ref:‘child’,
props: {
row: params.row
}
})
}
我们常见h函数的用法是:
render: (h) => {
return h(ele)
}
在es6中的用法,相当于 (h) => {} 相当于 function(){},上面的代码可解析为:
render: function(createElement) {
return createElement(ele);
}

Vue在创建Vue实例时,通过render作为函数来渲染Dom树,而在render方法中,又调用createElement函数来渲染子组件或元素。
因此此时元素或子组件处于渲染过程。
ref是用来给元素或子组件注册引用信息的,引用信息将会注册在父组件的$refs对象上。
因为 ref 本身是作为渲染结果被创建的,在初始渲染的时候你不能访问它们 - 它们还不存在!

解决办法
把h改为创建 this.$createElement

render: (h, params) => {
return this.$createElement(expandRow, {
ref:‘child’,
props: {
row: params.row
}
})
}
在这里插入图片描述
这样就可以打印出来了

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值