在 webworker 中运行 react virtual dom

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

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

【版权所有,侵权必究】【关注微信公众号:wwwtangshuangnet】未经授权,禁止复制转载。【版权所有】唐霜 www.tangshuang.net【版权所有,侵权必究】

之后,在同事的推荐和自己的寻找下,找到两著作权归作者所有,禁止商业用途转载。本文作者:唐霜,转载请注明出处。个项目:

【原创内容,转载请注明出处】原创内容,盗版必究。未经授权,禁止复制转载。

前一个项目比较老了,感觉正好符合我的想法本文作者:唐霜,转载请注明出处。本文作者:唐霜,转载请注明出处。。后一个项目受最近 server com本文版权归作者所有,未经授权不得转载。转载请注明出处:www.tangshuang.netponents 的启发才出来,也是非常有著作权归作者所有,禁止商业用途转载。【原创内容,转载请注明出处】意思。

转载请注明出处:www.tangshuang.net原创内容,盗版必究。【访问 www.tangshuang.net 获取更多精彩内容】

在深入想想。既然我们可以把计算过程放到 未经授权,禁止复制转载。本文作者:唐霜,转载请注明出处。worker 中,也可以放到 wasm 【本文受版权保护】未经授权,禁止复制转载。中去。我们可以用 rust 重写 vir原创内容,盗版必究。本文版权归作者所有,未经授权不得转载。tual dom 的实现,并像上面 wo著作权归作者所有,禁止商业用途转载。转载请注明出处:www.tangshuang.netrker 中的处理方式,放到 wasm 转载请注明出处:www.tangshuang.net【关注微信公众号:wwwtangshuangnet】中,通过接口传递数据,完成计算后再回调方【转载请注明来源】本文作者:唐霜,转载请注明出处。法,最终实现这个效果。

【原创内容,转载请注明出处】著作权归作者所有,禁止商业用途转载。【访问 www.tangshuang.net 获取更多精彩内容】

而以上这套思路,还有点像小程序的思路,但【版权所有,侵权必究】【作者:唐霜】最终还是不大相同。

【原创不易,请尊重版权】【本文受版权保护】本文版权归作者所有,未经授权不得转载。