React 服务器功能备忘单
时间:2024-12-25 16:43:03 488浏览 收藏
你在学习文章相关的知识吗?本文《React 服务器功能备忘单》,主要介绍的内容就涉及到,如果你想提升自己的开发能力,就不要错过这篇文章,大家要知道编程理论基础和实战操作都是不可或缺的哦!
React 服务器端功能详解
本文档概述了 React 服务器组件 (RSC) 和服务器函数的核心概念及使用方法。
核心概念
- 服务器组件 (RSC): 在服务器端运行并渲染为客户端 HTML 的组件。类似于服务器端渲染 (SSR),但效率更高。
- 服务器函数 (服务器操作): 仅在服务器端执行,并将数据传递给客户端的函数。
关键指令
'use client'
:用于标记客户端组件。在启用 RSC 的环境中,此指令必须位于文件顶部。'use server'
:用于标记服务器函数。此指令必须位于服务器组件的函数体或独立服务器函数文件的顶部。
服务器组件
- RSC 没有状态或生命周期方法。无法在 RSC 中使用诸如
useState
、useEffect
等 Hook。 - RSC 可以包含异步函数。
- RSC 可以调用服务器函数,但必须在函数体顶部使用
'use server'
指令。 - RSC 可以包含服务器组件和客户端组件作为子组件。
- RSC 无法直接访问浏览器 API。
- RSC 可以接收任何类型的 props,并将其传递给客户端组件。 下表列出了支持的 prop 类型。
示例:在服务器组件中读取并渲染 Markdown 文件
import marked from 'marked'; // 不包含在打包文件中
import sanitizeHtml from 'sanitize-html'; // 不包含在打包文件中
async function page({ page }) {
// 注意:在构建应用程序时,*渲染期间*加载。
const content = await file.readFile(`${page}.md`);
return <div>{sanitizeHtml(marked(content))}</div>;
}
服务器函数
- 定义服务器函数时,必须在函数体或文件中使用
'use server'
指令。 - 服务器函数可以在服务器端执行任何操作。
- 服务器函数无法访问浏览器 API。
- 服务器函数可以在服务器端和客户端调用。
- 服务器函数的返回值类型有限制。请参考下表。
示例:在服务器组件中声明服务器函数
import Button from './button';
function EmptyNote() {
async function createNoteAction() {
// 服务器函数
'use server';
await db.notes.create();
}
return <Button onClick={createNoteAction} />;
}
示例:在独立文件中声明服务器函数
"use server";
export async function updateName(name) {
if (!name) {
return { error: 'name is required' };
}
await db.users.updateName(name);
}
示例:在客户端组件中使用服务器函数
"use client";
import { updateName } from './actions';
function UpdateName() {
return (
<form action={updateName}>
<input name="name" type="text" />
</form>
);
}
数据类型兼容性
下表总结了 use client
和 use server
上下文中支持的数据类型:
类型 | `use client` | `use server` | 备注 |
---|---|---|---|
字符串 | ✅ | ✅ | 支持字符串值和可迭代对象。 |
数字 | ✅ | ✅ | |
BigInt | ✅ | ✅ | |
布尔值 | ✅ | ✅ | |
undefined | ✅ | ✅ | |
null | ✅ | ✅ | |
数组 | ✅ | ✅ | 仅限于可序列化列表的项。 |
Map | ✅ | ✅ | 仅限于可序列化列表的项。 |
Set | ✅ | ✅ | 仅限于可序列化列表的项。 |
TypedArray | ✅ | ✅ | |
ArrayBuffer | ✅ | ✅ | |
Date | ✅ | ✅ | |
对象 | ✅ | ✅ | 仅支持普通对象(对象初始化器或 JSON),不支持 null 原型。 |
Promise | ✅ | ✅ | 仅限于可序列化列表的项。 |
React 节点 | ✅ | ❌ | 只有服务器组件可以通过 props 将其传递到客户端组件。 |
FormData | ❌ | ✅ | 只有服务器函数才能返回 FormData 实例。 |
Symbol | ⚠️ | ⚠️ | 仅支持通过 `Symbol.for` 注册到全局 Symbol 注册表中的 Symbol。 |
函数 | ⚠️ | ⚠️ | 仅允许服务器函数。 |
类 | ❌ | ❌ | 任何实例对象都是不可序列化的。 |
其他类型和实例对象不可用。
希望以上信息对您有所帮助!
今天带大家了解了的相关知识,希望对你有所帮助;关于文章的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~
相关阅读
更多>
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
304 收藏
-
233 收藏
-
110 收藏
-
238 收藏
-
367 收藏
-
205 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习