首页前端开发JavaScriptReact嵌套组件的构建顺序

React嵌套组件的构建顺序

时间2024-02-01 09:12:02发布访客分类JavaScript浏览1136
导读:收集整理的这篇文章主要介绍了React嵌套组件的构建顺序,觉得挺不错的,现在分享给大家,也给大家做个参考。 目录在React官网中,可以看到对生命周期的描述接着看下嵌套组件接着看看传入多...
收集整理的这篇文章主要介绍了React嵌套组件的构建顺序,觉得挺不错的,现在分享给大家,也给大家做个参考。
目录
  • 在React官网中,可以看到对生命周期的描述
  • 接着看下嵌套组件
  • 接着看看传入多个组件
  • 构建总结
  • 偏离一点点主题
  • 最后总结

在React官网中,可以看到对生命周期的描述

这里有一个疑问是,在嵌套组件中,是父组件先构建,还是子组件先构建?是子组件先更新,还是父组件先更新

解决这个问题,可以从嵌套单个元素入手。下面是一个只有DOM元素的组件 Parent

function Parent(){
      return (    div>
    child/div>
  )}
    

对于上面的元素,React会调用React.createElement创建一个对象,这就是子元素的构建阶段(这里使用的是babeljs.io/)

React.createElement("div", null, "child")

构建之后就是渲染、更新

接着看下嵌套组件

function Child() {
      return div>
    child/div>
}
function Parent(){
      return (   Child>
    parent child/Child>
  )}
    

React会调用React.createElement,并传入以下参数

function Child() {
      return React.createElement("div", null, "child");
}
function Parent() {
      return React.createElement(Child, null, "parent child");
}
    

这里我们看出父子组件的构建过程,首先对当前组件进行构建,接着进入到组件中,继续构建,遵循的原则是从上到下

接着看看传入多个组件

function Child() {
      return div>
    child组件/div>
}
function Parent(){
      return (    div>
         div>
    div元素/div>
         Child />
        /div>
  )}
    

在React.createElement会传入以下参数

React.createElement("div", null, React.createElement("div", null, "div\u5143\u7D20"),React.createElement(Child, null))React.createElement("div", null, "child\u7EC4\u4EF6")

可以进一步明确,子组件的构建和父组件是分离的,并且是在父组件构建之后创建的。所以父子组件的构建顺序是父组件constructor,render子组件constructor,render

当子组件render完成后,会调用componentDidmount

构建总结

在多组件情况下,首先父元素constructor,进行初始化和开始挂载,接着调用render

对于DOM元素,会立即创建,对于React组件,会在之后进入到组件中,重复之前的constructor,构建,render,直到最后一个子元素

当最后一个子组件render完成后,会调用componentDidMount。也就是元素已经挂载完成。之后会层层向上,依次调用componentDidMount

偏离一点点主题

下面的代码可以辅助理解上面的内容

// RenderChild的作用是,当接收到值时,渲染children,没有值时,渲染其他元素function RenderChild(PRops){
      return (    props.a ? props.children : div>
    aaaa/div>
  )}
写法一(直接渲染DOM元素):function Parent(){
      let a = undefined;
      setTimeout(() =>
 {
    a = {
 b: 1 }
    ;
  }
    );
  return (    RenderChild val={
a}
    >
          div>
{
a.b}
    /div>
        /RenderChild>
  )}
写法二(渲染组件):function Child(props) {
      return div>
{
props.a.b}
    /div>
}
function Parent(){
      const a = undefined;
      setTimeout(() =>
 {
    a = {
 b: 1 }
    ;
  }
    );
  return (    RenderChild val={
a}
    >
      Child childVal={
a}
     />
        /RenderChild>
  )}
    

在上面两种写法中,第一种一定会报错

因为第一种的构建参数是

React.createElement(RenderChild, {
 val: a }
    ,React.createElement("div", null, a.b))此时a还是undefined

第二种构建参数是

function RenderChild(props) {
      return props.val ? props.children : React.createElement("div", null, "aaaa");
}
function Child(props) {
      return React.createElement("div", null, props.value.b);
}
React.createElement(RenderChild, {
 val: a }
, React.createElement(Child, {
    value: a }
    ));
    

因为Child的构建是在RenderChild之后的,所以即使在Child中使用到了不存在的值,也不会报错

最后总结

1. React组件的构建和开始挂载是从根元素到子元素的,因此数据流是从上到下的,挂载完成和状态的更新是从子元素到根元素,此时可以将最新状态传给根元素

2. 组件和DOM元素的一个区别是,DOM元素会在当前位置创建,而React组件的构建渲染具有层级顺序

以上就是React嵌套组件的构建顺序的详细内容,更多关于React嵌套组件的构建的资料请关注其它相关文章!

@H_689_126@您可能感兴趣的文章:
  • 编写简洁React组件的小技巧
  • 使用hooks写React组件需要注意的5个地方
  • react实现Radio组件的示例代码
  • 详解对于React结合Antd的Form组件实现登录功能
  • 基于react hooks,zarm组件库配置开发h5表单页面的实例代码
  • React antd tabs切换造成子组件重复刷新
  • 在react-antd中弹出层form内容传递给父组件的操作
  • 在react项目中使用antd的form组件,动态设置input框的值
  • react实现复选框全选和反选组件效果
  • @L_512_21@
  • 实例讲解React 组件生命周期
  • 实例讲解React 组件
  • 详解React 父组件和子组件的数据传输

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

React

若转载请注明出处: React嵌套组件的构建顺序
本文地址: https://pptw.com/jishu/595204.html
未能加载文件或程序集“AspNetPager”或它的某一个依赖项。拒绝访问 JavaScript自定义插件实现tabs切换功能

游客 回复需填写必要信息