大家好,我是若川。持续组织了8个月源码共读活动,感兴趣的可以点此加我微信 ruochuan12 参与,每周大家一起学习200行左右的源码,共同进步。同时极力推荐订阅我写的《学习源码整体架构系列》 包含20余篇源码文章。历史面试系列
2022年3月29号,React18
正式版发布。
从v16
开始,React
团队就在普及并发
的概念。在v18
的迭代过程中(alpha、Beta、RC),也一直在科普并发特性
,所以正式版发布时,已经没有什么新鲜特性。
本文主要讲解v18
发布日志中透露的一些未来发展趋势。
开发者可能并不会接触到并发特性
React
对增加API
是很慎重的。从13年诞生至今,触发更新的方式都是this.setState
。
而引入并发
概念后,光是与并发
相关的API
就有好几个,比如:
useTransition
useDeferredValue
甚至出现了为并发
兜底的API
(即并发情况下,不使用这些API可能会出bug),比如:
useSyncExternalStore
useInsertionEffect
一下多出这么多API
,还不是像useState
这种不使用不行的API
,况且,并发
这一特性对于多数前端开发者都有些陌生。
你可以代入自己的业务想想,让开发者上手使用并发特性
有多难。
所以,在未来用v18
开发的应用,「开发者可能并不会接触到并发特性」。这些特性更可能是由各种库封装好的。
比如:startTransition
可以让用户在不同视图间切换的同时,不阻塞用户输入。
这一API
很可能会由各种Router
实现,再作为一个配置项开放给开发者。
万物皆可Suspense
对于React
来说,有两类瓶颈需要解决:
CPU的瓶颈,如大计算量的操作导致页面卡顿
IO的瓶颈,如请求服务端数据时的等待时间
其中CPU的瓶颈
通过并发特性
的优先级中断机制解决。
IO的瓶颈
则交给Suspense
解决。
所以,未来一切与IO
相关的操作,都会收敛到Suspense
这一解决方案内。
从最初的React.lazy
到如今仍在开发中的Server Components
,最终万物皆可Suspense
。
这其中有些逻辑是很复杂的,比如:
Server Components
新的服务端渲染方案
所以,这些操作不大可能是直接面向开发者的。
这又回到了上一条,这些操作会交由各种库实现。如果复杂度更高,则会交由基于React
封装的框架实现,比如Next.js
、Remix
。
这也是为什么React团队
核心人物Sebastian
会加入Next.js
。
可以说,React
未来的定位是:一个前端底层操作系统,足够复杂,一般开发者慎用。
而开发者使用的是「基于该操作系统实现的各种上层应用」。
总结
如果说v16
之前各种React Like
库还能靠体积、性能优势分走React
部分蛋糕,那未来两者走的完全是两条赛道,因为两者的生态不再兼容。
未来不再会有React全家桶
的概念,桶里的各个部件最终会沦为更大的框架中的一个小模块。
当前你们业务里是直接使用React
呢,还是使用各种框架(比如Next.js
)?
················· 若川简介 ·················
你好,我是若川,毕业于江西高校。现在是一名前端开发“工程师”。写有《学习源码整体架构系列》20余篇,在知乎、掘金收获超百万阅读。
从2014年起,每年都会写一篇年度总结,已经坚持写了8年,点击查看年度总结。
同时,最近组织了源码共读活动,帮助3000+前端人学会看源码。公众号愿景:帮助5年内前端人走向前列。
扫码加我微信 ruochuan02、拉你进源码共读群
今日话题
略。分享、收藏、点赞、在看我的文章就是对我最大的支持~