https://react.dev/blog/2024/12/05/react-19
印象里 Suspense 和 Transition 这两个功能是 React 18 发布的。似乎 NextJS 之后,React 社区的焦点就变成了 SSR 和 RSC 。这两个功能一直没什么存在感,生态也很一般。
甚至直到现在,官方也没有说明第三方库该如何支持 Suspense:
The requirements for implementing a Suspense-enabled data source are unstable and undocumented. An official API for integrating data sources with Suspense will be released in a future version of React.
说实话这两个功能发布之后,我是一次也没用过。想问问大家用过这个两个 API 吗?体验如何?在新项目中是否会用这些 API ?
1
Track13 24 天前
要不是看到这个帖,我都不知道 react 19 已经发布,beta 有半年了吧。hooks 我都没有用过几个。感觉是给框架用的。
|
2
codehz 24 天前
其实 suspense 的核心就是在 render 阶段 throw 一个 promise ,只要保证 promise 的引用不变,就可以一直被 suspense 接住显示 fallback
然后 transition 就是能在下次 render 的时候 throw 另一个 promise 的时候暂时不显示 fallback 的内容(当然也可以不配合 suspense 用,单独用的情况就是可以标记里面触发的更新不应该 blocking ui ,ui 的 rerender 可以在后台完成后再展示 |
3
slert 24 天前
react 的新特性总感觉光看文档看不明白 有没有可能是往复杂的道路越走越远了
|
4
zsj1029 24 天前
越玩越花,2/8 定律,大抵是 8 成项目用不到的,不用研究
|
6
zhw2590582 24 天前
隔了几年没用 react, 现在完全不懂这些新概念
|
7
chesha1 24 天前
用是没有用过,但是学的时候学过: https://nextjs.org/learn/dashboard-app/streaming
所以说 Suspense 的存在感不可能低的,至少新学 nextjs 的人都会学一遍,至于用不用就不一定了 |
8
NessajCN 24 天前 via Android
这个特性就是原本手搓的
const [isLoading, setIsLoading] = useState(false); const onClick = async (e) => { setIsLoading(true); await some_action(); setIsLoading(false); } 给你个 hook 省得写起来啰嗦 实用性还是有的 但要说多大革新那就想多了 原本就能轻松实现的功能 |
9
iugo 24 天前
用过 Suspense, 挺好的. 但也不是不可替代.
目前 SSR 对我们意义不大, 即便使用 Next.js, 也是当作 CRA 的替代品. |
10
tcper 24 天前
最近做一些 css 动画,css 动画弄一个一直在那播的比较容易,但是如果想搞一个根据状态变化,播一次,保持状态,倒回来这种就非常麻烦。
react 要能解决这个问题比折腾这些 hook 强多了。 |
11
Nyeshuai 24 天前 via Android
Suspense 在根本的动态路由上就会碰到不算冷门把. Transition 项目太菜用不上. 19 的 普通 ref 和编译优化都是痛点更新,react 真没什么可挑的了,TS 指定省心框架。
|
12
iugo 24 天前
看了一下文档, 这是我们的经验总结: https://zsqk.github.io/news/2024-12-06-react-19.html
|