首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    关于React Hooks和Immutable性能优化的实践,我写了一本掘金小册

    上线了不到 5 天,没有任何推文介绍的情况下,销量已经超过 400,这个是我万万没想到的,不过这也侧面反映了各位掘友对我的信任。在后台大概看了一下 ID 名单,其中不乏熟悉的面孔,但更多的是几乎没什么印象甚至完全陌生的 ID,确实,回头看看在掘金这些日子的成长,写作、思考和挣扎的过程是极其痛苦的,但正是因为你偶然看到了文章,不经意点了赞、给了一些反馈,才让我有足够的斗志和毅力坚持下去。可能我们从未谋面,甚至互相连微信都没有,但就偏偏在一个叫"掘金"的地方,我收到了来自一个陌生人的认可,这种感觉从未有过,也是一直激励我不断坚持的动力。各位无论是期待已久还是偶尔打开这篇文章,请让我非常真诚地说上一声: 非常感谢!

    01

    React篇(010)-为什么虚拟 dom 会提高性能?

    答案: 虚拟dom(virtual dom) 其实就是一个JavaScript对象,通过这个JavaScript对象来描述真实dom。 真实dom:以前没有虚拟dom,如果需要比较两个页面的差异,我们需要通过对真实dom进行比对。真实dom节点是非常复杂的,它里面会绑定的事件,它会有属性,背后会有各种方法,会频繁触发重排与重绘,所以两个真实dom比对,非常耗性能。 总损耗 = 真实DOM完全增删改 + (可能较多的节点)重排与重绘 虚拟dom:相当于在js和真实dom中间加了一个缓存,利用dom diff算法避免了没有必要的dom操作,从而提髙性能。 总损耗 = 虚拟DOM增删改 + (与Diff算法效率有关)真实DOM差异增删改 + (较少的节点)重排与重绘 具体实现步骤如下: 1. 用JavaScript对象结构表示DOM树的结构;然后用这个树构建一个真正的DOM树,插到文档当中; 2. 当状态变更的时候,重新构造一棵新的对象树。然后用新的树和旧的树进行比较,记录两棵树差异; 3. 把步骤2所记录的差异应用到步骤1所构建的真正的DOM树上,视图就更新了。

    01
    领券