在 webworker 中运行 react virtual dom

广告位招租
扫码页面底部二维码联系

在一次内部分享会中,我表达了可以把 re【原创不易,请尊重版权】【原创内容,转载请注明出处】act 的 virtual dom 那一转载请注明出处:www.tangshuang.net【本文首发于唐霜的博客】套全部放到 webworker 中,这样原创内容,盗版必究。【本文受版权保护】就可以避免在主线程进行计算量很大的 di【本文首发于唐霜的博客】【作者:唐霜】ff 操作,一方面节省主线程的计算消耗提转载请注明出处:www.tangshuang.net本文版权归作者所有,未经授权不得转载。升性能,另一方面也不需要再去构建 rea【本文受版权保护】本文作者:唐霜,转载请注明出处。ct 的 scheduler 做那么复杂本文版权归作者所有,未经授权不得转载。【版权所有,侵权必究】的协程工程。大致意思就是,在主线程只做 本文版权归作者所有,未经授权不得转载。本文作者:唐霜,转载请注明出处。DOM 操作,而 DOM 的操作,全部由未经授权,禁止复制转载。【作者:唐霜】 worker 线程发送消息到主线程完成著作权归作者所有,禁止商业用途转载。【版权所有,侵权必究】。在 worker 中计算得到 patc本文作者:唐霜,转载请注明出处。转载请注明出处:www.tangshuang.nethes,发送到主线程,由主线程的程序完成【转载请注明来源】未经授权,禁止复制转载。 patch,也就是在主线程中,只存在 未经授权,禁止复制转载。本文作者:唐霜,转载请注明出处。DOM 操作,不存在计算过程。其中比较重【关注微信公众号:wwwtangshuangnet】【转载请注明来源】要的一点,是事件响应问题。当用户在界面上本文作者:唐霜,转载请注明出处。【原创内容,转载请注明出处】做了一次点击后,需要发送一个 event本文作者:唐霜,转载请注明出处。著作权归作者所有,禁止商业用途转载。 消息到 worker 中,然后由 wo本文版权归作者所有,未经授权不得转载。【原创内容,转载请注明出处】rker 中构建的一套事件处理系统完成事【作者:唐霜】【版权所有】唐霜 www.tangshuang.net件响应和接下来的 diff,将最终的 p本文作者:唐霜,转载请注明出处。【本文受版权保护】atch 发送回主线程。

【关注微信公众号:wwwtangshuangnet】【版权所有,侵权必究】【本文受版权保护】

之后,在同事的推荐和自己的寻找下,找到两【关注微信公众号:wwwtangshuangnet】未经授权,禁止复制转载。个项目:

【原创内容,转载请注明出处】原创内容,盗版必究。

前一个项目比较老了,感觉正好符合我的想法【版权所有】唐霜 www.tangshuang.net本文作者:唐霜,转载请注明出处。。后一个项目受最近 server com【未经授权禁止转载】本文作者:唐霜,转载请注明出处。ponents 的启发才出来,也是非常有【作者:唐霜】【关注微信公众号:wwwtangshuangnet】意思。

未经授权,禁止复制转载。未经授权,禁止复制转载。转载请注明出处:www.tangshuang.net【版权所有】唐霜 www.tangshuang.net

在深入想想。既然我们可以把计算过程放到 【原创不易,请尊重版权】【本文首发于唐霜的博客】worker 中,也可以放到 wasm 【访问 www.tangshuang.net 获取更多精彩内容】【版权所有】唐霜 www.tangshuang.net中去。我们可以用 rust 重写 vir本文版权归作者所有,未经授权不得转载。原创内容,盗版必究。tual dom 的实现,并像上面 wo【作者:唐霜】【作者:唐霜】rker 中的处理方式,放到 wasm 【本文首发于唐霜的博客】未经授权,禁止复制转载。中,通过接口传递数据,完成计算后再回调方未经授权,禁止复制转载。【访问 www.tangshuang.net 获取更多精彩内容】法,最终实现这个效果。

转载请注明出处:www.tangshuang.net著作权归作者所有,禁止商业用途转载。【未经授权禁止转载】

而以上这套思路,还有点像小程序的思路,但【原创不易,请尊重版权】著作权归作者所有,禁止商业用途转载。最终还是不大相同。

未经授权,禁止复制转载。【访问 www.tangshuang.net 获取更多精彩内容】【原创内容,转载请注明出处】【版权所有】唐霜 www.tangshuang.net