React Server feature basics
- Server Component (React Server Component, RSC): A component that runs on the server and renders to the client as the same as SSR.
- Server Function (a.k.a. Server Actions): A function that runs on the servers only and sends the information to the client.
Directives
- 'use client': If you are using a "server component" enabled environment, you should mark use client at the top of the file to mark it as a client component.
- 'use server': If you have a consideration of mutating the information on the server, you should mark use server directive at the top of the function body in the server component or file to operate only on the server.
Server Component
- RSC is no stateful nor lifecycle. You can't use any hook functions (useState, useEffect, etc.) on the server component.
- RSC can have an async function.
- RSC can have server functions. but you must mark 'use server' in the top of the function body.
- RSC can have children in both the server component and the client component.
- RSC cannot run any browser API.
- Your RSC can pass props of any type to RSC. also can pass props type with limitation to the client component. Check the directive types table below.
import marked from 'marked'; // Not included in bundle import sanitizeHtml from 'sanitize-html'; // Not included in bundle async function Page({page}) { // NOTE: loads *during* render, when the app is built. const content = await file.readFile(`${page}.md`); return <div>{sanitizeHtml(marked(content))}</div>; }
Server Function
- when definition, you must have the 'use server' directive in the function body or file.
- You can run any server features on the function body.
- You cannot run the browser API on the function body.
- You can call server functions on both the server and client.
- You can return value with limitations. Check the directive types table below.
Declaring server function in the server component
import Button from './Button'; function EmptyNote () { async function createNoteAction() { // Server Function 'use server'; await db.notes.create(); } return <Button onClick={createNoteAction}/>; }
Declaring server function in the separate file
"use server"; export async function updateName(name) { if (!name) { return {error: 'Name is required'}; } await db.users.updateName(name); }
Using server function in the client component
import marked from 'marked'; // Not included in bundle import sanitizeHtml from 'sanitize-html'; // Not included in bundle async function Page({page}) { // NOTE: loads *during* render, when the app is built. const content = await file.readFile(`${page}.md`); return <div>{sanitizeHtml(marked(content))}</div>; }
Comparison of handle value types in directives
- use client: passing prop type from server component to client component.
- use server: The return type of Server functions
Type | use client | use server | Notes |
---|---|---|---|
string | ? | ? | both string value and iterables are supported. |
number | ? | ? | |
bigint | ? | ? | |
boolean | ? | ? | |
undefined | ? | ? | |
null | ? | ? | |
Array | ? | ? | Only available in the item of serializable list. |
Map | ? | ? | Only available in the item of serializable list. |
Set | ? | ? | Only available in the item of serializable list. |
TypedArray | ? | ? | |
ArrayBuffer | ? | ? | |
Date | ? | ? | |
object | ? | ? | Support only plain object(object initializers or JSON), null prototype not supported. |
Promises | ? | ? | Only available in the serializable list. |
ReactNode | ? | ? | Only Server Component can send it to Client Component via props. |
FormData | ? | ? | Only server functions can return FormData instance. |
symbol | ?? | ?? | Only symbols registered in the global Symbol registry via Symbol.for |
function | ?? | ?? | Only server functions allowed. |
class | ? | ? | Any instance objects are not serializable. |
- The other types and instances are not available.
Happy react'ing!
The above is the detailed content of A React server feature cheat sheet. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

JavaScriptisidealforwebdevelopment,whileJavasuitslarge-scaleapplicationsandAndroiddevelopment.1)JavaScriptexcelsincreatinginteractivewebexperiencesandfull-stackdevelopmentwithNode.js.2)Javaisrobustforenterprisesoftwareandbackendsystems,offeringstrong

In JavaScript, choosing a single-line comment (//) or a multi-line comment (//) depends on the purpose and project requirements of the comment: 1. Use single-line comments for quick and inline interpretation; 2. Use multi-line comments for detailed documentation; 3. Maintain the consistency of the comment style; 4. Avoid over-annotation; 5. Ensure that the comments are updated synchronously with the code. Choosing the right annotation style can help improve the readability and maintainability of your code.

Yes,JavaScriptcommentsarenecessaryandshouldbeusedeffectively.1)Theyguidedevelopersthroughcodelogicandintent,2)arevitalincomplexprojects,and3)shouldenhanceclaritywithoutclutteringthecode.

JavaScriptcommentsareessentialformaintaining,reading,andguidingcodeexecution.1)Single-linecommentsareusedforquickexplanations.2)Multi-linecommentsexplaincomplexlogicorprovidedetaileddocumentation.3)Inlinecommentsclarifyspecificpartsofcode.Bestpractic

Java and JavaScript are different programming languages, each suitable for different application scenarios. Java is used for large enterprise and mobile application development, while JavaScript is mainly used for web page development.

CommentsarecrucialinJavaScriptformaintainingclarityandfosteringcollaboration.1)Theyhelpindebugging,onboarding,andunderstandingcodeevolution.2)Usesingle-linecommentsforquickexplanationsandmulti-linecommentsfordetaileddescriptions.3)Bestpracticesinclud

JavaScripthasseveralprimitivedatatypes:Number,String,Boolean,Undefined,Null,Symbol,andBigInt,andnon-primitivetypeslikeObjectandArray.Understandingtheseiscrucialforwritingefficient,bug-freecode:1)Numberusesa64-bitformat,leadingtofloating-pointissuesli

JavaScripthassevenfundamentaldatatypes:number,string,boolean,undefined,null,object,andsymbol.1)Numbersuseadouble-precisionformat,usefulforwidevaluerangesbutbecautiouswithfloating-pointarithmetic.2)Stringsareimmutable,useefficientconcatenationmethodsf
