在一次内部分享会中,我表达了可以把 re【关注微信公众号:wwwtangshuangnet】【本文首发于唐霜的博客】act 的 virtual dom 那一本文作者:唐霜,转载请注明出处。【本文受版权保护】套全部放到 webworker 中,这样著作权归作者所有,禁止商业用途转载。【未经授权禁止转载】就可以避免在主线程进行计算量很大的 di【转载请注明来源】原创内容,盗版必究。ff 操作,一方面节省主线程的计算消耗提【原创不易,请尊重版权】【访问 www.tangshuang.net 获取更多精彩内容】升性能,另一方面也不需要再去构建 rea转载请注明出处:www.tangshuang.net【版权所有】唐霜 www.tangshuang.netct 的 scheduler 做那么复杂【本文受版权保护】转载请注明出处:www.tangshuang.net的协程工程。大致意思就是,在主线程只做 【本文首发于唐霜的博客】【本文首发于唐霜的博客】DOM 操作,而 DOM 的操作,全部由【关注微信公众号:wwwtangshuangnet】著作权归作者所有,禁止商业用途转载。 worker 线程发送消息到主线程完成【版权所有,侵权必究】【版权所有】唐霜 www.tangshuang.net。在 worker 中计算得到 patc【本文受版权保护】【版权所有】唐霜 www.tangshuang.nethes,发送到主线程,由主线程的程序完成本文版权归作者所有,未经授权不得转载。著作权归作者所有,禁止商业用途转载。 patch,也就是在主线程中,只存在 【访问 www.tangshuang.net 获取更多精彩内容】【版权所有】唐霜 www.tangshuang.netDOM 操作,不存在计算过程。其中比较重【本文首发于唐霜的博客】【作者:唐霜】要的一点,是事件响应问题。当用户在界面上未经授权,禁止复制转载。【版权所有】唐霜 www.tangshuang.net做了一次点击后,需要发送一个 event【原创内容,转载请注明出处】未经授权,禁止复制转载。 消息到 worker 中,然后由 wo原创内容,盗版必究。著作权归作者所有,禁止商业用途转载。rker 中构建的一套事件处理系统完成事【关注微信公众号:wwwtangshuangnet】【版权所有,侵权必究】件响应和接下来的 diff,将最终的 p【版权所有】唐霜 www.tangshuang.net【原创内容,转载请注明出处】atch 发送回主线程。
未经授权,禁止复制转载。【访问 www.tangshuang.net 获取更多精彩内容】【版权所有,侵权必究】之后,在同事的推荐和自己的寻找下,找到两【本文首发于唐霜的博客】本文版权归作者所有,未经授权不得转载。个项目:
【原创内容,转载请注明出处】【版权所有,侵权必究】【未经授权禁止转载】- web-perf/react-worke转载请注明出处:www.tangshuang.net原创内容,盗版必究。r-dom: Experiments t【转载请注明来源】【本文受版权保护】o see the advantages转载请注明出处:www.tangshuang.net【未经授权禁止转载】 of using Web Worker原创内容,盗版必究。【版权所有】唐霜 www.tangshuang.nets to Render React Vi本文版权归作者所有,未经授权不得转载。【未经授权禁止转载】rtual DOM (github.co【转载请注明来源】【原创不易,请尊重版权】m) 【版权所有】唐霜 www.tangshuang.net原创内容,盗版必究。【转载请注明来源】
- dai-shi/react-worker【原创不易,请尊重版权】【未经授权禁止转载】-components: React W【本文首发于唐霜的博客】【版权所有】唐霜 www.tangshuang.netorker Components sim本文版权归作者所有,未经授权不得转载。【本文首发于唐霜的博客】plify using Web Work本文版权归作者所有,未经授权不得转载。【未经授权禁止转载】ers (github.com) 原创内容,盗版必究。【原创内容,转载请注明出处】著作权归作者所有,禁止商业用途转载。
- ampproject/worker-do原创内容,盗版必究。本文版权归作者所有,未经授权不得转载。m: The same DOM API 【版权所有,侵权必究】未经授权,禁止复制转载。and Frameworks you k【原创不易,请尊重版权】本文作者:唐霜,转载请注明出处。now, but in a Web Wo原创内容,盗版必究。著作权归作者所有,禁止商业用途转载。rker. (github.com) 著作权归作者所有,禁止商业用途转载。【原创内容,转载请注明出处】【关注微信公众号:wwwtangshuangnet】【访问 www.tangshuang.net 获取更多精彩内容】【关注微信公众号:wwwtangshuangnet】
前一个项目比较老了,感觉正好符合我的想法【关注微信公众号:wwwtangshuangnet】【版权所有,侵权必究】。后一个项目受最近 server com著作权归作者所有,禁止商业用途转载。【本文首发于唐霜的博客】ponents 的启发才出来,也是非常有本文版权归作者所有,未经授权不得转载。本文版权归作者所有,未经授权不得转载。意思。
【访问 www.tangshuang.net 获取更多精彩内容】【访问 www.tangshuang.net 获取更多精彩内容】著作权归作者所有,禁止商业用途转载。【作者:唐霜】著作权归作者所有,禁止商业用途转载。在深入想想。既然我们可以把计算过程放到 【访问 www.tangshuang.net 获取更多精彩内容】未经授权,禁止复制转载。worker 中,也可以放到 wasm 转载请注明出处:www.tangshuang.net【原创内容,转载请注明出处】中去。我们可以用 rust 重写 vir【关注微信公众号:wwwtangshuangnet】未经授权,禁止复制转载。tual dom 的实现,并像上面 wo著作权归作者所有,禁止商业用途转载。【本文受版权保护】rker 中的处理方式,放到 wasm 转载请注明出处:www.tangshuang.net【本文受版权保护】中,通过接口传递数据,完成计算后再回调方【作者:唐霜】原创内容,盗版必究。法,最终实现这个效果。
【原创不易,请尊重版权】【原创不易,请尊重版权】未经授权,禁止复制转载。而以上这套思路,还有点像小程序的思路,但著作权归作者所有,禁止商业用途转载。本文版权归作者所有,未经授权不得转载。最终还是不大相同。
【原创不易,请尊重版权】本文作者:唐霜,转载请注明出处。【原创内容,转载请注明出处】
