react 学习(六) 函数组件实例及类组件生命周期

本文介绍了在React中如何在函数组件中使用forwardRef方法,并展示了基本的组件生命周期,包括initialization、mounting、updation和unmounting阶段。通过示例代码解释了如何在不同生命周期阶段插入自定义操作。
摘要由CSDN通过智能技术生成

本小节开始前,我们先答复下一个同学的问题。上一小节发布后,有小伙伴后台来信问到:‘小编你只讲了类组件中怎么使用 ref,那在函数式组件中怎么使用呢?’。确实我们只分享了类组件中获取实例的方式没提函数式组件。那是因为函数组件是一个函数,执行完之后就会被销毁,所以正常我们不能直接获取函数组件的实例的。

那要是想使用的话怎么办呢?我们先看下正常给函数组件绑定 ref,会是什么效果:

function Fn(props) {
  return <h1>function</h1>;
}

costructor() {
  this.f = React.createRef()
}
render() {
  return (
    <div>
      <Fn ref={this.f} />
    </div>
  )
}

查看浏览器我们看到会打印如下的异常警告:这是告诉我们如果想函数组件使用 ref 的话需要使用 forwardRef 方法进行包裹。

function Fn(props, ref) {
  // 这里是获取的实例 dom
  return <h1 ref={ref}>function</h1>;
}
const Forward = React.forwardRef(Fn);

// 这样就可以获取到实例
<Forward ref={this.f} />

我们打印下返回的 Forward&

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值