百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

React 正在成为全栈框架

liuian 2024-12-03 16:31 37 浏览

React已经成为全栈型框架,前后端通吃。你准备好了吗?

React 已经添加了服务器组件和服务器操作,正在演变成一个全栈框架。它是曾经榜单中最流行的前端框架,现在成功地弥合了前后端之间的鸿沟,统治着两边的开发者。

我写这篇文章是因为以下的插图一直萦绕在脑海中。

2010 年,框架之战以 Backbone、Knockout 和 Ember 作为开端,随后 Angular 和 React 相继出现,没有人能够预测结果。

很长一段时间内,客户端渲染 (CSR) JavaScript 应用程序占据主导地位。这些应用程序也称为单页应用程序 (SPA),通常只是一个链接到大型 JavaScript 文件的小型 HTML 文件,直到代码分拆的出现。

在此期间,前端开发由各种 JavaScript 框架和库主导(Web 开发人员喜欢进行此讨论),而后端通常不与特定语言绑定,因为 REST 已经是 API 通信的标准。

在我担任自由 Web 开发人员的这些年里,我主要使用 .NET、Java、Python 和 PHP 作为后端。就我个人而言,我只在新建项目或小型项目时在后端看到过 TypeScript/JavaScript,我可以控制后端。然而,随着全栈 React 的兴起,这种情况正在改变。

回顾过去,我们发现开发人员对 2010 年至 2020 年期间的看法因其职业生涯开始时间的不同而存在差异,这很有趣。

2010 年之前入行的开发人员发现自己处于服务器端渲染 (SSR) 环境中,并且似乎对最近转向服务器端技术感到更适应。相比之下,许多其他人花了近十年时间只在客户端渲染 (CSR) 应用程序中使用 REST API。现在他们不知道该如何看待新的全栈 React 世界。

????????????????????????????????


????????????????????????????????


??????????????????????????????


???????????????????????????????


???????????????????????????????


???????????????????????????????


????????????????????????????????? 有人忘记了 SPA 吗?


????????????????????????????????


????????????????????????????????


???????????????????????????????


???????????????????????????????


????????????????????????????????


???????????????????????????????


???????????????????????????????


???????????????????????????????


???????????????????????????????


???????????????????????????????


???????????????????????????????


????????????????????????????????

但让我们回到正题上!近年来,TypeScript 已成为行业标准,为前端开发人员提供了一种类型化且更强大的编程语言。一旦开发人员接受了 TypeScript,就再也没有回头路了。

代码中一个相对较小的改变竟然会对个人和整个行业产生如此重大的影响,这真是令人着迷。

然而,TypeScript 对 REST 的影响涉及许多临时解决方案。虽然 OpenAPI(以前称为 Swagger)以前就存在,允许团队记录 REST API,但它的主要目的现在变成了生成类型化的 API 接口。尽管有可能在客户端-服务器架构中创建完美类型的接口,但根据我多年担任自由 Web 开发人员的经验,许多项目从一开始就未能正确实现它。

个人说明:可能有些开发人员对 OpenAPI 驱动的架构有积极的体验,但不幸的是我不是其中之一。

看到 TypeScript 如何改变这里的情绪,这相当有趣。一方面,使用 REST(以及用于文档目的的 OpenAPI)的非类型化 SPA 似乎“还行”。然而,一旦 TypeScript 成为标准并被视为常态,生成的类型接口就会变得难以使用,因为人们已经习惯了前端代码库中的更高标准。

生成类型接口的缺点很明显:

  • 总有一个世代相传的过程
  • 生成的输出很混乱
  • 根据初始设置,生成的代码并不总是正确的

介绍一位老朋友:RPC。

远程过程调用并不新鲜,并且由于 tRPC而变得流行,它们在 React 生态系统中越来越受欢迎。我作为一名独立开发人员在80k 行代码应用程序上工作了半年(2023 年)。从经验来看,调用后端函数来读取和写入数据是一种启示。在技术堆栈的两侧都使用 TypeScript 的环境里,我从未感到过如此高效的工作效率。

就我个人而言,几年前,只有在(生成的)类型化 GraphQL 架构中,我才感到了类似的高效。

有一年的时间(2023 年),我无法想象有什么比 tRPC 更好。仅使用一个函数来调用后端以读取和写入数据,这感觉这是革命性的。这就是我所需要的一切吗?不。对我来说,真正的突破来自 2024 年的服务器组件和服务器操作,它们不仅通过调用它,还能够在另一端实现和执行代码,从而弥合了与服务器之间的差距。

服务器组件允许我们在服务器上执行 React 组件,从而能够从数据源(例如数据库)直接访问,然后使用 JSX 返回 UI。

import { getMessages } from '@/messages/queries/';
const MessageList = async () => { 
 const messages = await getMessages(); 
  return ( 
     <ul>  
         {messages.map((message) => (     
            <li key={message.id}>{message.text}</li> 
          ))
          }    </ul>  
          );
  };
export { MessageList };

另一方面,服务器操作在后台创建 HTTP API 节点,可以通过执行函数像远程过程调用一样调用这些节点。

服务器组件和服务器操作将 React 转变为全栈框架,将前端转变为全栈环境是多么激动人心的时刻!

React 本身仅提供服务器组件和服务器操作的原语和规范。基于 React 构建的元框架可以通过其打包器弥补差距,后者负责解释客户端和服务器之间的指令(即'use client'和'use server')。

此外,Next.js 是 React 的领先元框架,率先实现了服务器组件和服务器操作。尽管 Next.js 之前已经支持服务器端渲染 (SSR),但服务器组件和服务器操作现在使开发者能够访问服务器端资源,例如数据库与消息队列。

这些标志着 React 全栈开发的开始。随着开发者开始通过服务器组件和服务器操作直接访问数据库,未来将有一个学习曲线来克服简单 CRUD 应用程序之外的复杂性。

通过全面的培训,前端开发人员很快就会掌握使用层、设计模式和最佳实践来实现后端架构。因为说句实话,没有人希望在 React 组件中看到 ORM 函数调用。

我对这种新范式转变感到兴奋!准备好迎接新时代吧,React 开发人员将实现从 UI 到数据库的垂直功能。我已经为这次旅程做好了准备,希望你也一样 :)

相关推荐

eino v0.4.5版本深度解析:接口类型处理优化与错误机制全面升级

近日,eino框架发布了v0.4.5版本,该版本在错误处理、类型安全、流处理机制以及代理配置注释等方面进行了多项优化与修复。本次更新共包含6个提交,涉及10个文件的修改,由2位贡献者共同完成。本文将详...

SpringBoot异常处理_springboot异常注解

在SpringBoot中,异常处理是构建健壮、可维护Web应用的关键部分。良好的异常处理机制可以统一返回格式、提升用户体验、便于调试和监控。以下是SpringBoot中处理异常的完整指...

Jenkins运维之路(Jenkins流水线改造Day02-1-容器项目)

这回对线上容器服务器的流水线进行了一定的改造来满足目前线上的需求,还是会将所有的自动化脚本都放置到代码库中统一管理,我感觉一章不一定写的完,所以先给标题加了个-1,话不多说开干1.本次流水线的流程设计...

告别宕机!零基础搭建服务器监控告警系统!小白也能学会!

前言本文将带你从零开始,一步步搭建一个完整的服务器指标监控与邮件告警系统,使用的技术栈均为业界主流、稳定可靠的开源工具:Prometheus:云原生时代的监控王者,擅长指标采集与告警规则定义Node_...

httprunner实战接口测试笔记,拿走不谢

每天进步一点点,关注我们哦,每天分享测试技术文章本文章出自【码同学软件测试】码同学公众号:自动化软件测试码同学抖音号:小码哥聊软件测试01开始安装跟创建项目pipinstallhttprunne...

基于JMeter的性能压测平台实现_jmeter压测方案

这篇文章已经是两年前写的,短短两年时间,JMeter开源应用技术的发展已经是翻天覆地,最初由github开源项目zyanycall/stressTestPlatform形成的这款测试工具也开始慢...

12K+ Star!新一代的开源持续测试工具!

大家好,我是Java陈序员。在企业软件研发的持续交付流程中,测试环节往往是影响效率的关键瓶颈,用例管理混乱、接口调试复杂、团队协作不畅、与DevOps流程脱节等问题都能影响软件交付。今天,给大家...

Spring Boot3 中分库分表之后如何合并查询

在当今互联网应用飞速发展的时代,数据量呈爆发式增长。对于互联网软件开发人员而言,如何高效管理和查询海量数据成为了一项关键挑战。分库分表技术应运而生,它能有效缓解单库单表数据量过大带来的性能瓶颈。而在...

离线在docker镜像方式部署ragflow0.17.2

经常项目上会出现不能连外网的情况,要怎么使用ragflow镜像部署呢,这里提供详细的步骤。1、下载基础镜像根据docker-compose-base.yml及docker-compose.yml中的i...

看,教你手写一个最简单的SpringBoot Starter

何为Starter?想必大家都使用过SpringBoot,在SpringBoot项目中,使用最多的无非就是各种各样的Starter了。那何为Starter呢?你可以理解为一个可拔插式...

《群星stellaris》军事基地跳出怎么办?解决方法一览

《群星stellaris》军事基地跳出情况有些小伙伴出现过这种情况,究竟该怎么解决呢?玩家“gmjdadk”分享的自己的解决方法,看看能不能解决。我用英文原版、德语、法语和俄语四个版本对比了一下,结果...

数据开发工具dbt手拉手教程-03.定义数据源模型

本章节介绍在dbt项目中,如何定义数据源模型。定义并引入数据源通过Extract和Load方式加载到仓库中的数据,可以使用dbt中的sources组件进行定义和描述。通过在dbt中将这些数据集(表)声...

docker compose 常用命令手册_docker-compose init

以下是DockerCompose常用命令手册,按生命周期管理、服务运维、构建配置、扩缩容、调试工具分类,附带参数解析、示例和关键说明,覆盖多容器编排核心场景:一、生命周期管理(核心命令...

RagFlow与DeepSeek R1本地知识库搭建详细步骤及代码实现

一、环境准备硬件要求独立显卡(建议NVIDIAGPU,8GB显存以上)内存16GB以上,推荐32GB(处理大规模文档时更高效)SSD硬盘(加速文档解析与检索)软件安装bash#必装组件Docker...

Docker Compose 配置更新指南_docker-compose配置

高效管理容器配置变更的最佳实践方法重启范围保留数据卷适用场景docker-composeup-d变更的服务常规配置更新--force-recreate指定/所有服务强制重建down→up流程...