在一次内部分享会中,我表达了可以把 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【版权所有,侵权必究】之后,在同事的推荐和自己的寻找下,找到两著作权归作者所有,禁止商业用途转载。本文作者:唐霜,转载请注明出处。个项目:
【原创内容,转载请注明出处】原创内容,盗版必究。未经授权,禁止复制转载。- web-perf/react-worke【本文首发于唐霜的博客】【转载请注明来源】r-dom: Experiments t【原创不易,请尊重版权】本文作者:唐霜,转载请注明出处。o see the advantages著作权归作者所有,禁止商业用途转载。【访问 www.tangshuang.net 获取更多精彩内容】 of using Web Worker【本文受版权保护】本文作者:唐霜,转载请注明出处。s to Render React Vi【关注微信公众号:wwwtangshuangnet】【作者:唐霜】rtual DOM (github.co本文版权归作者所有,未经授权不得转载。未经授权,禁止复制转载。m) 【本文受版权保护】原创内容,盗版必究。本文作者:唐霜,转载请注明出处。转载请注明出处:www.tangshuang.net
- dai-shi/react-worker【本文受版权保护】转载请注明出处:www.tangshuang.net-components: React W【作者:唐霜】【版权所有,侵权必究】orker Components sim【原创不易,请尊重版权】【原创内容,转载请注明出处】plify using Web Work本文作者:唐霜,转载请注明出处。【转载请注明来源】ers (github.com) 著作权归作者所有,禁止商业用途转载。【本文受版权保护】【版权所有】唐霜 www.tangshuang.net【本文受版权保护】
- ampproject/worker-do著作权归作者所有,禁止商业用途转载。原创内容,盗版必究。m: The same DOM API 著作权归作者所有,禁止商业用途转载。【原创内容,转载请注明出处】and Frameworks you k【访问 www.tangshuang.net 获取更多精彩内容】【版权所有】唐霜 www.tangshuang.netnow, but in a Web Wo【关注微信公众号:wwwtangshuangnet】【本文首发于唐霜的博客】rker. (github.com) 【未经授权禁止转载】【作者:唐霜】【版权所有】唐霜 www.tangshuang.net【访问 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 获取更多精彩内容】而以上这套思路,还有点像小程序的思路,但【版权所有,侵权必究】【作者:唐霜】最终还是不大相同。
【原创不易,请尊重版权】【本文受版权保护】本文版权归作者所有,未经授权不得转载。
