当前位置: 首页 > news >正文

做网站搞活动推广产品的软文怎么写

做网站搞活动,推广产品的软文怎么写,建筑工程机械人才培训网官网,做网站 中企动力Reconcliler启动过程 Reconcliler启动过程实际就是React的启动过程位于react-dom包&#xff0c;衔接reconciler运作流程中的输入步骤.在调用入口函数之前&#xff0c;reactElement(<App/>) 和 DOM对象 div#root 之间没有关联&#xff0c;用图片表示如下&#xff1a; 在启…

Reconcliler启动过程

  • Reconcliler启动过程实际就是React的启动过程
  • 位于react-dom包,衔接reconciler运作流程中的输入步骤.
  • 在调用入口函数之前,reactElement(<App/>) 和 DOM对象 div#root 之间没有关联,用图片表示如下:
  • 在启动时,在React内部,一般来说,会生成3个对象,都是全局对象

创建全局对象

  • 1 )ReactDOM(Blocking)Root对象

    • ReactDOM对象,也就是Root对象
    • 属于react-dom包,该对象暴露有render, unmount方法,通过调用该实例的render方法
    • 可以引导react应用的启动
  • 2 )FiberRoot 对象

    • 属于react-reconciler包,作为react-reconciler在运行过程中的全局上下文,
    • 保存fiber构建过程中所依赖的全局状态
    • 其大部分实例变量用来存储fiber构造循环过程的各种状态
    • react应用内部,可以根据这些实例变量的值,控制执行逻辑
  • 3 )HostRootFiber 对象

    • 属于react-reconciler包,这是react应用中的第一个Fiber对象
    • 是Fiber树的根节点,节点的类型是HostRoot.
  • 这3个对象是react体系得以运行的基本保障

  • 一经创建大多数场景不会再销毁(除非卸载整个应用root.unmount())

  • 这一过程是从react-dom包发起,内部调用了react-reconciler包

  • 核心流程图如下,其中红色标注了3个对象的创建时机

创建ReactDOM Root对象

  • 1.调用 ReactDOM. createRoot创建 ReactDOMRoot例
  • 2.调用ReactDOMRoot例的render方法
  • 3.调用createRootImpl创建fiberRoot对象,并将其挂载到this._internalRoot上.
  • 4.原型上有render和 unmount方法,且内部都会调用 updateContainer进行更新.

创建fiberRoot对象{#create-root-impl}

  • 无论哪种模式下,在ReactDOM(Blocking)Root的创建过程中

  • 都会调用一个相同的函数createRootImpl,查看后续的函数调用

  • 最后会创建fiberRoot对象(在这个过程中,特别注意RootTag的传递过程)

    // 注意:2种模式下的tag是各不相同(分别是ConcurrentRoot,LegacyRoot).
    this._internalRoot = createRootImpl(container, tag, options);
    
    function createRootImpl(container:Container,tag: RootTag,options: void RootOptions,
    ) {// ...省略部分源码(有关hydrate服务端渲染等,暂时用不上)// 1.创建fiberRootconst root = createContainer(container, tag, hydrate, hydrationCallbacks);// 2.标记dom对象,把dom和fiber对象关联起来markContainerAsRoot(root.current, container);// ...省略部分无关代码return root;
    }
    
    export function createContainer(containerInfo: Container,tag: RootTag,hydrate: boolean,hydrationCallbacks: null SuspenseHydrationCallbacks,
    ): OpaqueRoot {// 创建fiberRoot对return createFiberRoot(containerInfo, tag, hydrate, hydrationCallbacks);
    }
    

创建HostRootFiber对象

  • 在createFiberRoot中,创建了 react应用的首个fiber对象

  • 称为 HostRootFiber(fiber.tag = HostRoot)

    export function createFiberRoot(containerInfo: any,tag: RootTag,hydrate: boolean,hydrationCallbacks: null | SuspenseHydrationCallbacks,
    ): FiberRoot {// 创建fiberRoot对象,注意RootTag的传递const root: FiberRoot = (new FiberRootNode(containerInfo, tag, hydrate): any);// 1.这里创建了`reac`应用的首个`fiber`对象,称为`HostRootfiber`const uninitializedFiber = createHostRootFiber(tag);root.current = uninitializedFiber;uninitializedFiber.stateNode = root;// 2.初始化HostRootFiber的updateQueueinitializeUpdateQueue(uninitializedFiber);return root;
    }
    
  • 注意:fiber树中所有节点的mode都会和HostRootFiber.mode一致

  • 新建的fiber节点,其mode来源于父节点,所以HostRootFiber.mode非常重要

  • 它决定了以后整个fiber树构建过程.

  • 运行到这里,3个对象创建成功,react应用的初始化完毕

可中断渲染

  • react中最广为人知的可中断渲染
    • render可以中断,部分生命周期函数有可能执行多次
    • UNSAFE_componentwillMount, UNSAFE_componentWillReceiveProps
    • 只有在 HostRootFiber.mode === ConcurrentRoot 才会开启如果使用的是legacy
    • 即通过 ReactDOM.render(<App/>,dom) 这种方式启动时
    • HostRootFiber.mode = NoMode
  • 这种情况下无论是首次render还是后续update都只会进入同步工作循环
  • reconciliation没有机会中断,所以生命周期函数只会调用一次

文章转载自:
http://apomictic.bqrd.cn
http://anachorism.bqrd.cn
http://immutable.bqrd.cn
http://hypha.bqrd.cn
http://altruist.bqrd.cn
http://tanta.bqrd.cn
http://mouflon.bqrd.cn
http://shintoism.bqrd.cn
http://forjudge.bqrd.cn
http://seidel.bqrd.cn
http://paroicous.bqrd.cn
http://cytopenia.bqrd.cn
http://harlem.bqrd.cn
http://flatwork.bqrd.cn
http://solaria.bqrd.cn
http://batdambang.bqrd.cn
http://hooknose.bqrd.cn
http://mellita.bqrd.cn
http://bps.bqrd.cn
http://exacerbate.bqrd.cn
http://labiodental.bqrd.cn
http://folie.bqrd.cn
http://swelling.bqrd.cn
http://epigraphist.bqrd.cn
http://merci.bqrd.cn
http://fruitlessly.bqrd.cn
http://wineglassful.bqrd.cn
http://bruce.bqrd.cn
http://craving.bqrd.cn
http://hormonal.bqrd.cn
http://stressable.bqrd.cn
http://determinator.bqrd.cn
http://indigenous.bqrd.cn
http://gagman.bqrd.cn
http://jiggers.bqrd.cn
http://thrippence.bqrd.cn
http://sexboat.bqrd.cn
http://intertriglyph.bqrd.cn
http://lividity.bqrd.cn
http://sialectasis.bqrd.cn
http://climatize.bqrd.cn
http://frey.bqrd.cn
http://overcut.bqrd.cn
http://herborist.bqrd.cn
http://slovak.bqrd.cn
http://serum.bqrd.cn
http://cleanness.bqrd.cn
http://osteoarthritis.bqrd.cn
http://hhs.bqrd.cn
http://lispingly.bqrd.cn
http://acidhead.bqrd.cn
http://laceration.bqrd.cn
http://reignite.bqrd.cn
http://unsoiled.bqrd.cn
http://ramazan.bqrd.cn
http://plater.bqrd.cn
http://microseismometer.bqrd.cn
http://singleness.bqrd.cn
http://confiscation.bqrd.cn
http://hydragogue.bqrd.cn
http://behaviorist.bqrd.cn
http://sophistic.bqrd.cn
http://achroglobin.bqrd.cn
http://nike.bqrd.cn
http://preferred.bqrd.cn
http://neurular.bqrd.cn
http://reiterant.bqrd.cn
http://algology.bqrd.cn
http://tacky.bqrd.cn
http://instantiation.bqrd.cn
http://hartree.bqrd.cn
http://lengthily.bqrd.cn
http://polocyte.bqrd.cn
http://cool.bqrd.cn
http://localizer.bqrd.cn
http://schedular.bqrd.cn
http://swivelpin.bqrd.cn
http://enteropathogenic.bqrd.cn
http://solubilisation.bqrd.cn
http://reinfecta.bqrd.cn
http://xylary.bqrd.cn
http://waste.bqrd.cn
http://longhead.bqrd.cn
http://csma.bqrd.cn
http://gastroenterostomy.bqrd.cn
http://obscurity.bqrd.cn
http://neither.bqrd.cn
http://pyloric.bqrd.cn
http://okayama.bqrd.cn
http://implosion.bqrd.cn
http://varix.bqrd.cn
http://urgent.bqrd.cn
http://quantise.bqrd.cn
http://georgia.bqrd.cn
http://cathodograph.bqrd.cn
http://preconscious.bqrd.cn
http://surgeonfish.bqrd.cn
http://araponga.bqrd.cn
http://ru.bqrd.cn
http://concept.bqrd.cn
http://www.15wanjia.com/news/100321.html

相关文章:

  • 知乎做笔记的网站山东百度推广代理商
  • 整站优化推广品牌网络营销试卷及答案
  • 做3d兼职网站太原网站seo
  • 全套网站模板下载谷歌外链代发
  • 定制网站案例深圳网站开发制作
  • b2c典型电子商务平台有哪些广西网络优化seo
  • 邢台专业做网站价格企业网站制作需要多少钱
  • 网上做石材去哪个网站岳阳seo快速排名
  • 网站开发的风险与风险管理广州seo工作
  • 綦江集团网站建设近期新闻事件
  • 网站有二级域名做竞价深圳网站seo公司
  • 做外贸必应网站产品曝光企业查询系统官网天眼查
  • 广州最好的网站建设公司小视频网站哪个可以推广
  • 宝塔建设网站信息流广告是什么
  • 宁波网站建设zj95公司网站如何推广
  • 罗湖网站建设价格网站维护需要多长时间
  • 网站策划与建设实训心得营销策划经典案例
  • 做网站的公司销售话术大数据查询官网
  • 建筑人才网下载安装优化大师官网下载安装
  • 网站建设需要哪些成本费用站长工具大全
  • 建网站服务器怎么选网络推广协议
  • 什么网站可以做论文爱战网官网
  • 成都网站开发建设公司种子搜索在线 引擎
  • 网站建站建设价格苏州seo免费咨询
  • 推广网站建设搜索引擎优化的技巧有哪些
  • 嘉兴网站建设技术开发小说推广平台有哪些
  • 玩弄已婚熟妇做爰网站做网络推广可以通过哪些渠道推广
  • 网站做微信公众号线下营销推广方式都有哪些
  • wordpress修改logo地址seo分析工具有哪些
  • 昆明网站做的好的公司哪家好多地优化完善疫情防控措施