RV大战之2024年我还想写React

原文地址:blog.hophop.work/rv2024react...
全文纯属个人观点,words are my own.

大家好,我是HopHop。

近期又上演了一场 React/Vue 大战,我也借这个时间点大概聊一聊自己对于React以及前端目前渲染类库的理解。

问题陈述

前端的框架/库要解决核心问题就是页面渲染,很多框架/库在解决渲染问题时,主要采用:

  1. 自建DSL + 编译时 + 运行时 (Vue, React)
  2. 自建DSL + 编译时 (Svelte)
  3. 纯运行时 (jQuery)

React的解决方案是纯运行时解决方案。JSX的compile时编译不对运行时代码做任何优化,不属于任何性能优化的范畴。

以上3点是目前主流的前端渲染库/框架的解决方案。但是无非是想要做到

  1. 相对优雅的DX
  2. 检测数据变更 → 【differ + 更新】或 【更新 + differ】

React在设想整个UI界面时,是完全围绕view = fn(data)的纯函数核心思想。

此纯函数核心思想即:

  1. 一份数据,对应一份UI
  2. 任何副作用需标明是副作用

同时再通过一些"技术手段"保证每次data的变更后,fn可以持续稳定一致的执行,不断的differ,最终影响到ui的变更。可以理解为优化手段完全控制在运行时。

在这种前提下,React需要给出闭包的各种hack解法,例如:

  1. JavaScript闭包带来的各类快照
  2. 状态记忆和清理
  3. 各类快照的对比

这也就带来了很多新手会碰到的DX问题,例如useRef, useState的选择,useEffect的概念和onMount概念的区别等等,甚至加入了strict mode,在dev模式下强制执行两遍effect来保证用户代码的正确运作。

所以其实对于React来说,每一步设计的加入都是相当的困难,因为目前的DX体验已经完全走下坡路了。在设计API时,不仅要考虑到开发者体验(写法,理解能力),还要为了保证内部很多的hack手段的正常工作。

React在官网上花了无数的笔墨去解释很多hook的内部到底是怎么工作,用户应该如何编写去让这些hook正确运作,例如

官方的一些compile时的优化想法

用一些新的hook来解决已有的DX问题:

React的hook理念在推出之初绝对是相当革新的设计,但是目前React在这条路上已经没法回头了🥺

我觉得就搞搞React Server Component挺好的,狗头保命(

相关推荐
苏打水com2 小时前
第九篇:Day25-27 Vue进阶——组件复用与状态管理(对标职场“复杂项目”需求)
前端·javascript·vue.js
PineappleCoder2 小时前
别让页面 “鬼畜跳”!Google 钦点的 3 个性能指标,治好了我 80% 的用户投诉
前端·性能优化
卤代烃2 小时前
🕹️ [AI] Chrome DevTools MCP 原理分析
前端·mcp
梦里不知身是客112 小时前
flink对于迟到数据的处理
前端·javascript·flink
卤代烃3 小时前
🤝 了解 CDP (Chrome DevTools Protocol):browser-use 背后的隐藏功臣
前端·chrome·puppeteer
一 乐3 小时前
人事管理系统|基于Springboot+vue的企业人力资源管理系统设计与实现(源码+数据库+文档)
java·前端·javascript·数据库·vue.js·spring boot·后端
b***74883 小时前
前端状态系统的时代变革:从本地状态到全局状态,再到智能状态的未来趋势
前端·状态模式
秋氘渔3 小时前
Vue 3 组合式API中的生命周期钩子函数介绍
前端·javascript·vue.js
拉不动的猪3 小时前
requestAnimationFrame 与 JS 事件循环:宏任务执行顺序分析
前端·javascript·面试
步步为营DotNet3 小时前
深度解析C# 11的Required成员:编译期验证保障数据完整性
java·前端·c#