首页 web前端 js教程 React 服务器组件:演变

React 服务器组件:演变

Jan 08, 2025 am 08:30 AM

React Server Components: The Evolution

简介

大约十年前,当我开始软件开发之路时,我只编写了 HTML、CSS、JavaScript 和一些 Python 2 脚本;在那段时间,我们仅依赖 PHP 和 SQL 进行服务器端客户端-服务器通信。之后,下一个层次是神奇的词“反应”,就像对状态或效果的变化做出反应。这是我的理解,没有深入探讨这个问题,有传言说是 Facebook 工程师制作的;这是我们用来编码前端部分的方式的重磅炸弹。

随着软件开发的发展和后端系统变得复杂,React Server Components (RSC) 认为我们的生态系统迫切需要发展。这让我想起了大量 JavaScript 捆绑包和“加载”旋转器无处不在的日子。让我们探索 RSC 如何改变游戏规则。

性能革命

RSC 带来的主要转变不仅是技术上的,而且是哲学上的。 RSC 不需要将整个组件树发送到客户端,而是让我们在服务器上渲染组件,同时保持我们喜欢的 React 交互性。我曾经将仪表板应用程序迁移到 RSC,这非常简单,没有什么特别的,而且仪表板应用程序的大小下降了 60%,效果明显。

这是我最近遇到的一个现实世界的例子:

 // Before: Client Component
 import { ComplexDataGrid } from 'heavy-grid-library';
import { format } from 'date-fns';

export default function Dashboard() {
  const [data, setData] = useState([]);

  useEffect(() => {
    fetchDashboardData().then(setData);
  }, []);

  return <ComplexDataGrid data={data} />;
}

在这种传统的客户端方法中,发生了几件事:

  • 我们正在导入一个与我们的客户端 JavaScript 捆绑在一起的重型数据网格库。
  • 我们使用 useState 在浏览器中本地管理我们的数据。
  • 我们在组件安装后使用 useEffect 获取数据。
  • 在获取数据时用户会看到加载状态。
  • 所有数据处理都在浏览器中进行,可能会降低用户设备的速度。

现在,让我们看看 RSC 版本:

import { sql } from '@vercel/postgres';
import { DataGrid } from './DataGrid';

export default async function Dashboard() {
  const data = await sql`SELECT * FROM dashboard_metrics`;

  return <DataGrid data={data} />;
}
  • 该组件默认是异步的 - 不需要 useEffect 或 useState。
  • 通过服务器端查询直接访问数据库。
  • 无需客户端数据获取代码。
  • 初始数据需要零加载状态。
  • 数据处理发生在强大的服务器上,而不是用户设备上。
  • 导入的DataGrid组件可以更轻量,因为它只需要处理显示,而不是数据获取。

转变是惊人的。不再有 useEffect,不再有客户端数据获取,最重要的是,不再有不必​​要的 JavaScript 传送到客户端。

现实世界的好处

影响不仅仅限于性能指标。在使用 RSC 时,我注意到数据库查询现在更靠近数据源(在上面的示例中不是最佳编码实践),组件更简单、更集中,身份验证和授权模式变得更简单,并且 SEO改进几乎是免费的,这在 React 世界中是从未发生过的。

然而,最显着的优势是开发者体验。编写可以直接访问数据库的组件(安全!)感觉就像一种超能力。这就像两全其美:React 基于组件的架构,以及 Next.js 最先进的服务器端渲染的性能优势

权衡

说实话:RSC 并不完美。心智模型需要时间来掌握,尤其是理解客户端/服务器边界;对我来说,这是一种黑匣子中的复杂操作。我将遵循之前的迁移示例,我们遇到了一些与 RSC 不兼容的第三方库的障碍。解决方案是什么?混合方法:

 // Before: Client Component
 import { ComplexDataGrid } from 'heavy-grid-library';
import { format } from 'date-fns';

export default function Dashboard() {
  const [data, setData] = useState([]);

  useEffect(() => {
    fetchDashboardData().then(setData);
  }, []);

  return <ComplexDataGrid data={data} />;
}

让我们来分解一下这种混合方法中发生的情况:

  • use client 指令显式地将 SearchFilter 标记为客户端组件。
  • SearchFilter 处理只能在客户端上发生的用户交互(onChange 事件)。
  • ProductList 仍然是一个服务器组件,在服务器端获取数据。
  • 组件组合允许我们在适当的情况下混合服务器和客户端渲染。
  • 只有交互部分(SearchFilter)将 JavaScript 传送到客户端。
  • 数据密集的部分(包含产品的 ProductGrid)在服务器上呈现。

结论(未来是服务器优先)

RSC 代表的不仅仅是一个新功能 - 它是我们构建 React 应用程序时所传达的范例。将昂贵的计算和数据获取转移到服务器,同时维护 React 的组件模型的能力是革命性的。

对于构建数据量大的应用程序的团队来说,RSC 提供了一条在不牺牲开发人员体验的情况下获得更好性能的途径。随着环境的成熟和更多库与 RSC 兼容,我预计这种模式将成为我们构建 React 应用程序的默认方式。

分享您的经验

您开始在项目中使用 React Server 组件了吗?我很乐意在下面的评论中听到您的意见、挑战和胜利。
如果本文帮助您更好地了解 RSC,请点赞,并且不要忘记关注我以更深入地了解现代系统。

关于作者

Ivan Duarte 是一位拥有自由职业经验的后端开发人员。他对网络开发和人工智能充满热情,并喜欢通过教程和文章分享他们的知识。在 X、Github 和 LinkedIn 上关注我,获取更多见解和更新。

订阅我们的时事通讯

直接在收件箱中阅读来自 ByteUp 的文章。

订阅时事通讯,不要错过。

立即订阅 ?

以上是React 服务器组件:演变的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

PHP教程
1517
276
高级JavaScript范围和上下文 高级JavaScript范围和上下文 Jul 24, 2025 am 12:42 AM

JavaScript的作用域决定变量可访问范围,分为全局、函数和块级作用域;上下文决定this的指向,依赖函数调用方式。1.作用域包括全局作用域(任何地方可访问)、函数作用域(仅函数内有效)、块级作用域(let和const在{}内有效)。2.执行上下文包含变量对象、作用域链和this的值,this在普通函数指向全局或undefined,在方法调用指向调用对象,在构造函数指向新对象,也可用call/apply/bind显式指定。3.闭包是指函数访问并记住外部作用域变量,常用于封装和缓存,但可能引发

VUE 3组成API与选项API:详细比较 VUE 3组成API与选项API:详细比较 Jul 25, 2025 am 03:46 AM

Vue3中CompositionAPI更适合复杂逻辑和类型推导,OptionsAPI适合简单场景和初学者;1.OptionsAPI按data、methods等选项组织代码,结构清晰但复杂组件易碎片化;2.CompositionAPI用setup集中相关逻辑,利于维护和复用;3.CompositionAPI通过composable函数实现无冲突、可参数化的逻辑复用,优于mixin;4.CompositionAPI对TypeScript支持更好,类型推导更精准;5.两者性能和打包体积无显着差异;6.

如何使用JS获取所选广播按钮的值? 如何使用JS获取所选广播按钮的值? Jul 18, 2025 am 04:17 AM

获取选中的单选按钮值的核心方法有两种。1.使用querySelector直接获取选中项,通过input[name="your-radio-name"]:checked选择器获取选中的元素并读取其value属性,适合现代浏览器且代码简洁;2.使用document.getElementsByName遍历查找,通过循环NodeList找到第一个checked的radio并获取其值,适合兼容旧浏览器或需要手动控制流程的场景;此外需注意name属性拼写、处理未选中情况以及动态加载内容时

在JavaScript中探索类型的强制规则 在JavaScript中探索类型的强制规则 Jul 21, 2025 am 02:31 AM

类型强制转换是JavaScript中自动将一种类型的值转为另一种类型的行为,常见场景包括:1.使用 运算符时,若其中一边为字符串,另一边也会被转为字符串,如'5' 5结果为"55";2.布尔上下文中非布尔值会被隐式转为布尔类型,如空字符串、0、null、undefined等被视为false;3.null参与数值运算会转为0,而undefined会转为NaN;4.可通过显式转换函数如Number()、String()、Boolean()避免隐式转换带来的问题。掌握这些规则有助于

掌握JavaScript并发模式:网络工人与Java线程 掌握JavaScript并发模式:网络工人与Java线程 Jul 25, 2025 am 04:31 AM

JavaScript的WebWorkers和JavaThreads在并发处理上有本质区别。1.JavaScript采用单线程模型,WebWorkers是浏览器提供的独立线程,适合执行不阻塞UI的耗时任务,但不能操作DOM;2.Java从语言层面支持真正的多线程,通过Thread类创建,适用于复杂并发逻辑和服务器端处理;3.WebWorkers使用postMessage()与主线程通信,安全隔离性强;Java线程可共享内存,需注意同步问题;4.WebWorkers更适合前端并行计算,如图像处理,而

如何在JS中格式化日期? 如何在JS中格式化日期? Jul 20, 2025 am 12:10 AM

在JavaScript中格式化日期可通过原生方法或第三方库实现。1.使用原生Date对象拼接:通过getFullYear、getMonth、getDate等方法获取日期部分,手动拼接成YYYY-MM-DD等格式,适合轻量需求且不依赖第三方库;2.使用toLocaleDateString方法:可按本地习惯输出如MM/DD/YYYY格式,支持多语言但格式可能因环境不同而不一致;3.使用第三方库如day.js或date-fns:提供简洁语法和丰富功能,适合频繁操作或需要扩展性时使用,例如dayjs()

用node.js构建CLI工具 用node.js构建CLI工具 Jul 24, 2025 am 03:39 AM

初始化项目并创建package.json;2.创建带shebang的入口脚本index.js;3.在package.json中通过bin字段注册命令;4.使用yargs等库解析命令行参数;5.用npmlink本地测试;6.添加帮助、版本和选项增强体验;7.可选地通过npmpublish发布;8.可选地用yargs实现自动补全;最终通过合理结构和用户体验设计打造实用的CLI工具,完成自动化任务或分发小工具,以完整句⼦结束。

如何在JS中创建和附加元素? 如何在JS中创建和附加元素? Jul 25, 2025 am 03:56 AM

使用document.createElement()创建新元素;2.通过textContent、classList、setAttribute等方法自定义元素;3.使用appendChild()或更灵活的append()方法将元素添加到DOM中;4.可选地使用insertBefore()、before()等方法控制插入位置;完整流程为创建→自定义→添加,即可动态更新页面内容。

See all articles