Next.js 是一个全栈式的 React 框架。它用途广泛,可以让你创建任意规模的 React 应用——可以是静态博客,也可以是复杂的动态应用。要创建一个新的 Next.js 项目,请在你的终端运行:
npx create-next-app@latest
如果你是 Next.js 的新手,请查看 Next.js 教程。
Next.js 由 Vercel 维护。你可以 将 Next.js 应用 部署到 Node.js 或 serverless 上,也可以部署到你自己的服务器上。完全静态的 Next.js 应用 可以部署在任何支持静态服务的地方。
Node版本要求在18.17以上,建议使用nvm切换
打开终端(官网建议使用create-next-app
创建Next应用)
npx create-next-app@latest
接下来将看到如下提示:根据自己的习惯进行选择,这里我全选Yes,最后回车
What is your project named? my-next-app
Would you like to use TypeScript? No / Yes
Would you like to use ESLint? No / Yes
Would you like to use Tailwind CSS? No / Yes
Would you like to use src/ directory? No / Yes
Would you like to use App Router? (recommended) No / Yes
Would you like to customize the default import alias (@/)? No / Yes
What import alias would you like configured? @/
注意:选择使用项目根目录中的src目录将应用程序代码与配置文件分开。这和我选择的方式是一致的
Dashboard | Clerk.com 官网
Add authentication and user management to your Next.js app with Clerk in 7 minutes | Clerk
https://clerk.com/docs/quickstarts/nextjs 文档
npm install @clerk/nextjs
NEXT_PUBLIC_CLERK_PUBLISHABLE_KEY=pk_test_c2FjcmVkLWd1cHB5LTE4LmNsZXJrLmFjY291bnRzLmRldiQ
CLERK_SECRET_KEY=sk_test_••••••••••••••••••••••••••••••••••
在根目录创建.env.local文件把上面copy到文件中
我们这里选择app router这个是比较常用的
修改/src/app/layout.tsx
import { ClerkProvider } from '@clerk/nextjs'
export default function RootLayout({
children,
}: {
children: React.ReactNode
}) {
return (
{children}
)
}
在src/创建middleware.ts
import { authMiddleware } from "@clerk/nextjs";
// This example protects all routes including api/trpc routes
// Please edit this to allow other routes to be public as needed.
// See https://clerk.com/docs/references/nextjs/auth-middleware for more information about configuring your Middleware
export default authMiddleware({});
export const config = {
matcher: ['/((?!.+\\.[\\w]+$|_next).*)', '/', '/(api|trpc)(.*)'],
};
在app/page.tsx文件加入
import { UserButton } from "@clerk/nextjs";
export default function Home() {
return (
)
}
启动项目(到这里就完成了!)
npm run dev
来控制你登陆的状态
待更新!!