怎么卸载node,windows彻底卸载nodejs

本篇是详细解读ReactDOM操作的第一篇文章,文章所讲的内容发生在commit阶段。Fiber架构使得React需要维护两类树结构,一类是Fiber树,另一类是DOM树。当删除DOM节点时,Fibe

本篇是详细解读React DOM操作的第一篇文章,文章所讲的内容发生在commit阶段。

Fiber架构使得React需要维护两类树结构,一类是Fiber树,另一类是DOM树。当删除DOM节点时,Fiber树也要同步变化。但请注意删除操作执行的时机:在完成DOM节点的其他变化(增、改)前,要先删除fiber节点,避免其他操作被干扰。 这是因为进行其他DOM操作时需要循环fiber树,此时如果有需要删除的fiber节点却还没删除的话,就会发生混乱。

function commitMutationEffects(firstChild: Fiber, root: FiberRoot, renderPriorityLevel,) {let fiber = firstChild;while (fiber !== null) {// 首先进行删除const deletions = fiber.deletions;if (deletions !== null) {commitMutationEffectsDeletions(deletions,root,renderPriorityLevel);}// 如果删除之后的fiber还有子节点,// 递归调用commitMutationEffects来处理if (fiber.child !== null) {const primarySubtreeTag = fiber.subtreeTag & MutationSubtreeTag;if (primarySubtreeTag !== NoSubtreeTag) {commitMutationEffects(fiber.child,root,renderPriorityLevel);}}if (__DEV__) {/*...*/} else {// 执行其他DOM操作try {commitMutationEffectsImpl(fiber,root,renderPriorityLevel);} catch (error) {captureCommitPhaseError(fiber,error);}}fiber = fiber.sibling;}}

fiber.deletions是render阶段的diff过程检测到fiber的子节点如果有需要被删除的,就会被加到这里来。

commitDeletion函数是删除节点的入口,它通过调用unmountHostComponents实现删除。搞懂删除操作之前,先看看场景。

有如下的Fiber树,Node(Node是一个代号,并不指的某个具体节点)节点即将被删除。

Fiber树 div#root|<App/>| div| <Parent/>| Delation -->Node| ↖| ↖P ——————> <Child>|a

通过这种场景可以推测出当删除该节点时,它下面子树中的所有节点都要被删除。现在直接以这个场景为例,走一下删除过程。这个过程实际上也就是unmountHostComponents函数的运行机制。

怎么卸载node

删除过程

删除Node节点需要父DOM节点的参与:

parentInstance.removeChild(child)

所以首先要定位到父级节点。过程是在Fiber树中,以Node的父节点为起点往上找,找到的第一个原生DOM节点即为父节点。在例子中,父节点就是div。此后以Node为起点,遍历子树,子树也是fiber树,因此遍历是深度优先遍历,将每个子节点都删除。

需要特别注意的一点是,对循环节点进行删除,每个节点都会被删除操作去处理,这里的每个节点是fiber节点而不是DOM节点。DOM节点的删除时机是从Node开始遍历进行删除的时候,遇到了第一个原生DOM节点(HostComponent或HostText)这个时刻,在删除了它子树的所有fiber节点后,才会被删除。

以上是完整过程的简述,对于详细过程要明确几个关键函数的职责和调用关系才行。删除fiber节点的是unmountHostComponents函数,被删除的节点称为目标节点,它的职责为:

找到目标节点的DOM层面的父节点

判断目标节点如果是原生DOM类型的节点,那么执行3、4,否则先卸载自己之后再往下找到原生DOM类型的节点之后再执行3、4

遍历子树执行fiber节点的卸载

删除目标节点的DOM节点

其中第3步的操作,windows彻底卸载nodejs,是通过commitNestedUnmounts完成的,它的职责很单一也很明确,就是遍历子树卸载节点。

然后具体到每个节点的卸载过程,由commitUnmount完成。它的职责是

Ref的卸载

如果是通过brew安装的,则直接使用 brew uninstall node 若不是或者已经通过brew卸载了,则(删除之前,确认一下文件是否存在,并且是否为应该删除的文件)然后通过 node npm 检查一下,是否把应用卸载好了,ok了即可重新安装 。

类组件生命周期的调用

HostPortal类型的fiber节点递归调用unmountHostComponents重复删除过程

下面来看一下不同类型的组件它们的具体删除过程是怎样的。

区分被删除组件的类别

Node节点的类型有多种可能性,我们以最典型的三种类型(HostComponent、ClassComponent、HostPortal)为例分别说明一下删除过程。

首先执行unmountHostComponents,会向上找到DOM层面的父节点,然后根据下面的三种组件类型分别处理,我们挨个来看。

进入 /usr/local/lib 删除所有 node 和 node_modules文件夹 进入 /usr/local/include 删除所有 node 和 node_modules 文件夹 检查 ~ 文件夹里面的"local" "lib" "include" 文件夹,然后删除里面的所有 "node。

HostComponent

Node 是HostComponent,调用commitNestedUnmounts,以Node为起点,遍历子树,开始对所有子Fiber进行卸载操作,遍历的过程是深度优先遍历。

Delation -->Node(span)|↖| ↖P ——————> <Child>|a

Node的fiber被卸载,然后向下,p的fiber被卸载,p没有child,找到它的sibling<Child>,<Child>的fiber被卸载,向下找到a,a的fiber被卸载。此时到了整个子树的叶子节点,开始向上return。由a 到 <Child>,再回到Node,遍历卸载的过程结束。

在子树的所有fiber节点都被卸载之后,才可以安全地将Node的DOM节点从父节点中移除。

ClassComponent

Delation -->Node(ClassComponent)|| span|↖| ↖P ——————> <Child>|a

Node是ClassComponent,它没有对应的DOM节点,要先调用commitUnmount卸载它自己,之后会先往下找,找到第一个原生DOM类型的节点span,以它为起点遍历子树,确保每一个fiber节点都被卸载,之后再将span从父节点中删除。

Mac 下 彻底卸载Node 终端命令:sudo npm uninstall npm -g sudo rm -rf /usr/local/lib/node /usr/local/lib/node_modules /var/db/receipts/org.nodejs.sudo rm -rf /usr/local/include/node /Users/$USER/.np。

HostPortal

div2(Container Of Node)↗ div containerInfo|↗|↗ Delation -->Node(HostPortal)|| span|↖| ↖P ——————> <Child>|a

Node是HostPortal,它没有对应的DOM节点,因此删除过程和ClassComponent基本一致,不同的是删除它下面第一个子fiber的DOM节点时不是从这个被删除的HostPortal类型节点的DOM层面的父节点中删除,而是从HostPortal的containerInfo中移除,图示上为div2,因为HostPortal会将子节点渲染到父组件以外的DOM节点。

commitUnmount

FunctionComponent 函数组件中一旦调用了useEffect,那么它卸载的时候要去调用useEffect的销毁函数。(useLayoutEffect的销毁函数是调用commitHookEffectListUnmount执行的)

ClassComponent 类组件要调用componentWillUnmount

HostComponent 要卸载ref

总结

我们来复盘一下删除过程中的重点:

删除操作执行的时机

怎么卸载node

删除的目标是谁

从哪里删除

mutation在基于Fiber节点对DOM做其他操作之前,需要先删除节点,保证留给后续操作的fiber节点都是有效的。删除的目标是Fiber节点及其子树和Fiber节点对应的DOM节点,整个轨迹循着fiber树,对目标节点和所有子节点都进行卸载,对目标节点对应的(或之下的第一个)DOM节点进行删除。对于原生DOM类型的节点,直接从其父DOM节点删除,对于HostPortal节点,它会把子节点渲染到外部的DOM节点,所以会从这个DOM节点中删除。明确以上三个点再结合上述梳理的过程,就可以逐渐理清删除操作的脉络。

看完三件事❤️

如果你觉得这篇内容对你还蛮有帮助,我想邀请你帮我三个小忙:

点赞,转发,有你们的 『点赞和评论』,才是我创造的动力。

关注头条号 『 JAVA后端架构 』,不定期分享原创知识。

同时可以期待后续文章ing

关注作者后台私信【888】有惊喜相送

上一篇 2023年02月05 23:30
下一篇 2023年04月11 10:09

相关推荐

  • qps多少才算高并发,5000并发的qps是多少

    作者:边鹏_尛爺鑫来源:大家心里仔细想想,当你们听到高并发网站时,心里对这个网站是个什么概念?首先想到的是淘宝吗?带着问题,我们一起思考技术~写这个话题是因为我对搜索引擎给我的答案很不满意,然后决定把

    2023年02月24 221
  • 土星有多少颗卫星,太阳系173颗卫星大小排名

    编者按:"浩瀚的空天还有许多未知的奥秘有待探索",太阳系173颗卫星大小排名,为此,中科院之声与中国科学院国家空间科学中心联合开设“Calling太空”科普专栏,为大家讲述有趣的故事,介绍一些与空间科

    2023年02月23 202
  • 小箭头怎么去掉,一键去除快捷方式箭头

    桌面上那些五颜六色的图标,一键去除快捷方式箭头,这些图标都有一个共同的特点,在每个图标的左下角都有一个非常小的箭头。这个箭头就是用来表明该图标是一个快捷方式的。快捷方式是Windows提供的一种快速启

    2023年02月07 239
  • 2k显示器分辨率是多少,电脑为什么不建议买2k屏幕

    从显示器发展的角度来看,高分辨率肯定是重要的发展趋势。随着显示面板成本的下降,如今2K、4K显示器基本已经实现了普及。不过,电脑为什么不建议买2k屏幕,还有很多人依旧会选择购买1080P分辨率的显示器

    2023年02月23 201
  • 百度竞价多少钱

    本文作者:胖九​前两天有个学员说到:“零几年我做竞价的时候,都不用做什么操作,把关键词放上去,出个几块钱块钱,每天就有六七个电话,多的时候可能会有十来个,但是现在不行了,现在出价二三十块钱,四五十块钱

    2023年02月20 223
  • github怎么注册

    GitHub,全球最大同性交友网站!作为一个IT人员,不管是运维亦或是编程人员,都要了解下GitHub的使用。本文中假设用户名为chenqiufei1.注册账号1、打开GitHub主页:https:/

    2023年02月06 277
  • ios怎么更新系统

    iOS15沿用iOS14的设计风格,UI没有大的变化。主要新增了一些新功能和优化了部分功能。主要升级的功能有:通知中心、天气App、地图;增加的功能有:专注模式、照片实况文本、门禁卡。升级通知中心iO

    2023年02月15 202
  • 中国的国家代码是多少,中国国家代码电话

    古有黄明祖训序,四方诸夷,皆限山隔海,僻在一隅;那么古代的夷子国有哪些呢?东北“朝鲜国”,历史上称作“高丽“(公元918年-1392年),又称高丽王朝、王氏高丽;大体上相当于今天朝鲜半岛中南部;日本国

    2023年02月22 293
  • 苹果6plus换壳多少钱,苹果6splus换外壳多少钱

    本内容来源于@什么值得买APP,观点仅代表作者本人|作者:乱买指南和全世界的好男人一样,每年老婆升级手机的时候也是我最快乐的时候,我就终于能用上老婆去年的新手机!所以每次给老婆挑手机我也是非常积极,毕

    2023年04月06 253
  • 飞利浦剃须刀多少钱,30元一50元的电动剃须刀

    剃须刀作为一个男人除了手机之外每天都要用的产品,决定了你每天一两分钟的剃须体验,一年下来就是累积6个多小时,30元一50元的电动剃须刀,所以剃须刀一定要选择品质和经典款的。而根据之前评论区的经验,呼声

    2023年03月08 233
  • 淘宝今年多少亿,怎么看淘宝用了多少年

    营收2055.6亿,净利润227.39亿8月4日,阿里巴巴集团公布了2023财年第一季度业绩。财报显示,自2022年4月1日至2022年6月30日,集团营收2055.6亿元,与上年同期基本持平。4月至

    2023年04月08 280
  • 微信的城市服务在哪里阿,微信城市服务在哪里设置关闭

    辞虎迎兔辞之际,突(兔)飞猛进,2022年12月21日,通知签名:缴存调整2021年(7月—12月补缴)的住房公积金。正当时上网课,微信城市服务在哪里设置关闭,那个速度堪比深圳速度!是前所未有的!,1

    2023年02月17 206
  • 怎么做风筝,手工制作一个真手机

    今天带来一个简单好玩的小鸟风筝~到底有多简单呢?!只!需!关!键!一!步!就能完成哟~红豆小朋友举着风筝飞奔的时候,直呼太爽啦~~~做风筝的制作过程步骤如下:材料准备:细竹条或者有韧性的细棒、裁纸刀、

    2023年02月10 216
关注微信