宣布 React SDK 完全支持 React 服务器组件
Next.js 中 App Router 范例的引入给开发人员构建和构造应用程序的方式带来了重大变化。虽然它为 React Server Components (RSC) 等令人兴奋的功能和对渲染的更精细控制打开了大门,但它也为需要无缝支持客户端和服务器端环境的包带来了复杂性。
随着 @storyblok/react 4.0.0 版的发布,我们很自豪能够在 Next.js 中提供对 React 服务器组件的全面支持。此更新简化了实施,在我们的可视化编辑器中启用实时预览功能,并确保强大的服务器渲染,所有这些都在一个统一的设置中。
立即开始使用它:
npm i @storyblok/react@4
如果您将 @storyblok/react v3 与 App Router 一起使用,则会发生一些重大更改。请继续阅读本文以了解如何更新您的应用。
@storyblok/react 4.0.0 有什么新功能?
以下是此版本中主要改进的快速概述:
统一 RSC 支持
以前,Next.js 中的 React 服务器组件需要两种不同的实现来实现兼容性。在 4.0.0 版本中,我们简化了这一过程,并将所有内容整合为一种一致的方法。使用可视化编辑器进行实时预览
使用 App Router 的开发者现在可以直接在 Storyblok 可视化编辑器中享受实时预览功能,从而增强开发和内容编辑体验。无缝服务器渲染
利用 Next.js 的完整服务器渲染功能来提高应用程序的性能和可扩展性
如何使用
第1步:初始化SDK
首先创建一个新文件 lib/storyblok.js 来初始化 SDK。确保导出 getStoryblokApi() 函数。
// lib/storyblok.js import Page from '@/components/Page'; import Teaser from '@/components/Teaser'; import { apiPlugin, storyblokInit } from '@storyblok/react/rsc'; export const getStoryblokApi = storyblokInit({ accessToken: 'YOUR_ACCESS_TOKEN', use: [apiPlugin], components: { teaser: Teaser, page: Page, }, });
getStoryblokApi() 函数返回 Storyblok 客户端的共享实例,该实例跨服务器和客户端组件工作。
第 2 步:使用 StoryblokProvider 包装您的应用程序
接下来,创建一个 StoryblokProvider 组件以在客户端启用实时编辑。使用此提供程序将整个应用程序包装在 app/layout.jsx 文件中。
// app/layout.jsx import StoryblokProvider from '@/components/StoryblokProvider'; export default function RootLayout({ children }) { return ( <StoryblokProvider> <html lang="en"> <body>{children}</body> </html> </StoryblokProvider> ); }
现在,创建 StoryblokProvider 组件:
// components/StoryblokProvider.jsx 'use client'; import { getStoryblokApi } from '@/lib/storyblok'; export default function StoryblokProvider({ children }) { getStoryblokApi(); // Re-initialize on the client return children; }
请注意,StoryblokProvider 是一个客户端组件。这可确保您的客户端组件可以与 Storyblok 交互,包括在可视化编辑器中进行实时编辑。
第 3 步:获取内容和渲染组件
在服务器组件中,使用 getStoryblokApi() 函数从 Storyblok 获取内容。这是一个示例 app/page.jsx 文件。
npm i @storyblok/react@4
步骤4:使用StoryblokServerComponent进行服务端渲染
要动态渲染组件,请始终使用 @storyblok/react/rsc 中的 StoryblokServerComponent。
// lib/storyblok.js import Page from '@/components/Page'; import Teaser from '@/components/Teaser'; import { apiPlugin, storyblokInit } from '@storyblok/react/rsc'; export const getStoryblokApi = storyblokInit({ accessToken: 'YOUR_ACCESS_TOKEN', use: [apiPlugin], components: { teaser: Teaser, page: Page, }, });
这确保了与服务器端渲染的兼容性,即使您将组件声明为客户端组件也是如此。
接下来是什么?
我们正在准备更新的官方文档,以使版本 4 的采用更加顺利。同时,所有基本步骤都包含在自述文件中。
您的反馈和贡献对于改进@storyblok/react 至关重要!如果您有建议或问题,请随时提出问题或直接为项目做出贡献。
以上是宣布 React SDK 完全支持 React 服务器组件的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

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

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

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

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

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

Python更适合初学者,学习曲线平缓,语法简洁;JavaScript适合前端开发,学习曲线较陡,语法灵活。1.Python语法直观,适用于数据科学和后端开发。2.JavaScript灵活,广泛用于前端和服务器端编程。

JavaScript在Web开发中的主要用途包括客户端交互、表单验证和异步通信。1)通过DOM操作实现动态内容更新和用户交互;2)在用户提交数据前进行客户端验证,提高用户体验;3)通过AJAX技术实现与服务器的无刷新通信。

JavaScript在现实世界中的应用包括前端和后端开发。1)通过构建TODO列表应用展示前端应用,涉及DOM操作和事件处理。2)通过Node.js和Express构建RESTfulAPI展示后端应用。

理解JavaScript引擎内部工作原理对开发者重要,因为它能帮助编写更高效的代码并理解性能瓶颈和优化策略。1)引擎的工作流程包括解析、编译和执行三个阶段;2)执行过程中,引擎会进行动态优化,如内联缓存和隐藏类;3)最佳实践包括避免全局变量、优化循环、使用const和let,以及避免过度使用闭包。

Python和JavaScript在社区、库和资源方面的对比各有优劣。1)Python社区友好,适合初学者,但前端开发资源不如JavaScript丰富。2)Python在数据科学和机器学习库方面强大,JavaScript则在前端开发库和框架上更胜一筹。3)两者的学习资源都丰富,但Python适合从官方文档开始,JavaScript则以MDNWebDocs为佳。选择应基于项目需求和个人兴趣。

Python和JavaScript在开发环境上的选择都很重要。1)Python的开发环境包括PyCharm、JupyterNotebook和Anaconda,适合数据科学和快速原型开发。2)JavaScript的开发环境包括Node.js、VSCode和Webpack,适用于前端和后端开发。根据项目需求选择合适的工具可以提高开发效率和项目成功率。

C和C 在JavaScript引擎中扮演了至关重要的角色,主要用于实现解释器和JIT编译器。 1)C 用于解析JavaScript源码并生成抽象语法树。 2)C 负责生成和执行字节码。 3)C 实现JIT编译器,在运行时优化和编译热点代码,显着提高JavaScript的执行效率。

Python更适合数据科学和自动化,JavaScript更适合前端和全栈开发。1.Python在数据科学和机器学习中表现出色,使用NumPy、Pandas等库进行数据处理和建模。2.Python在自动化和脚本编写方面简洁高效。3.JavaScript在前端开发中不可或缺,用于构建动态网页和单页面应用。4.JavaScript通过Node.js在后端开发中发挥作用,支持全栈开发。
