想要引用被react-redux库connect高阶组件包裹的WrappedComponent的ref的坑

在React中,想要在父组件引用子组件的属性或方法就需要使用ref将子组件的组件实例在父组件中引入。

但是如果子组件export的是使用react-redux库的connect函数封装的话

export default connect(mapStateToProps, mapDispatchToProps)(ChildComponent)

在父组件render函数中渲染子组件

<ChildComponent ref={this.childComponent = ref} />

时获取ref会报错,提示

Function components cannot be given refs. Attempts to access this ref will fail. Did you mean to use React.forwardRef()?

这个原因是connect函数是会使用一个匿名父组件render被包裹元素,而这个匿名父组件还会在一个外部function中被返回,而React不允许渲染function组件的事件引入ref,所以报warning,父组件的childComponent变量肯定也拿不到东西。

怎么样解决这个问题就是需要将内部的子组件ref透传出来,在以前的react-redux版本中,connect函数的第四个参数options对象可以将withRef置为true,这样connected的新匿名组件就会将ref传递到被包裹的子组件中,开发者渲染的connected component就可以拿到目标子组件的ref实例,故


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值