如何在nextjs的app目录的根布局/页面中使用useState



在Nextjs 13 -实验应用程序目录中,如果我想在根布局/页面上使用useState,我必须在代码中添加' use client ',这有效地防止了所有嵌套组件成为服务器组件。我如何解决这个问题,这样我就可以使用useState并仍然拥有服务器组件。感谢所有回应者。

我不知道这是否回答了你的问题(最好添加一些示例代码来帮助用户理解你的问题)

如果你创建了一个服务器组件,并在该组件中添加了你的客户端组件,它会正常工作。例如

ClientComponent.tsx

"use client";
import {useState} from 'react';
export default function ClientComponent() {
const [count, setCount] = useState(0);
return (
<>
<h1>Client Component</h1>
<p>Count: {count}</p>
<button onClick={() => setCount(count + 1)}>Increment</button>
</>
)
}

ServerComponent.tsx

async function getData(){
const res = await fetch('http://localhost:3000/api/hello');
return await res.json();
}
export default async function ServerComponent() {
const data = await getData()
return (
<>
<h1>Server Component</h1>
<p>{data.name}</p>
</>
)
}

Api hello.ts

export default async function handler(req, res) {
res.status(200).json({ name: 'John Doe' })
}

页面

import ClientComponent from "./ClientComponent";
import ServerComponent from "./ServerComponent";
export default function Page() {
return(<>
<ClientComponent/>
<ServerComponent/>
</>
)
}

在这个例子中,ServerComponent在服务器端呈现,而ClientComponent在客户端呈现,所以它保持交互性

希望这对你有帮助

我怎样才能解决这个问题,这样我就可以使用useState,仍然有服务器组件

这不可能。服务器组件意味着组件的初始呈现在发送到客户端之前发生在服务器上。这可以通过减少首次呈现的时间和增强整体用户体验来提高性能。这就是服务器组件的全部意义所在。您已与浏览器隔离。useState是react.js客户端特定的代码。它只在浏览器端工作。其目的是在useState值发生变化时向用户显示更新后的组件。所以你不能在服务器上使用useState

看起来你可以使用"searchParams"获取。这也意味着您有一个提交值的按钮。

https://nextjs.org/docs/app/api-reference/functions/use-search-params

最新更新