Nextjs15 基础配置使用

Nextjs15 基础配置使用

起步

注意:node 版本 V18.18 以上

pnpm dlx create-next-app@latest 创建一个nextjs 15项目的基本结构模板

  1. src/app 下文件夹会自动生成应用路由

例如:创建 src/about/page.tsx ,就会自动生成路由 /about, 访问这个路由会自动展示src/about/page.tsx 页面

  1. 也可以创建嵌套路由

例如:src/app/blog/first-post/page.tsx ,就会自动生成路由 /blog/first-post, 访问这个路由会自动展示src/app/blog/first-post/page.tsx 页面

  1. 可以创建动态路由

例如:src/app/products/[id]/page.tsx, 就会自动生成路由 /products/[id], 当访问该路由,则会自动展示src/app/products/[id]/page.tsx 页面。 该页面也可以通过params 获取id 参数

ts 复制代码
const ProductInfo = async ({ params }: { params: { id: string } }) => {
  const { id } = await params
  return <div>products info: {id}</div>
}

export default ProductInfo
  1. 也可以创建文件夹,但是创建路由的时候忽略当前文件夹。

例如:src/app/(auth)/login/page.tsx , 用小括号包裹,此时访问该页面的路由其实是/login

  1. app/latout.tsx 可以书写共享UI
tsx 复制代码
...
export default function RootLayout({
  children
}: Readonly<{
  children: React.ReactNode
}>) {
  return (
    <html lang="en">
      <body
        className={`${geistSans.variable} ${geistMono.variable} antialiased`}
      >
        <header className="bg-slate-900 text-white p-4 text-center">
          <p> Welcome to Nextjs</p>
        </header>
        {children}
        <footer className="bg-slate-900 text-white p-4 text-center">
          Code volution
        </footer>
      </body>
    </html>
  )
}
  1. 其他的page.tsx 文件统计目录下也可以有自己的layout.tsx, 作用是为这个对应路由下提供公共的 layout 布局
tsx 复制代码
const ProductLayout = ({
  children
}: Readonly<{
  children: React.ReactNode
}>) => {
  return (
    <>
      {children}
      <h4>Feature product section</h4>
    </>
  )
}

export default ProductLayout
  1. 可以在src/components 下创建 navigation.tsx 作为导航,引入layout.tsx 供用户跳转路由使用, Link,usePathname 的使用可以观察以下代码
tsx 复制代码
'use client'
import Link from 'next/link'
import { usePathname } from 'next/navigation'

export default function Navigation() {
  const pathname = usePathname()
  const homeClass =
    pathname === '/' ? 'mr-4 text-white-500' : 'mr-4 text-blue-500'
  const aboutClass =
    pathname === '/about' ? 'mr-4 text-white-500' : 'mr-4 text-blue-500'
  const productClass =
    pathname === '/products/1' ? 'mr-4 text-white-500' : 'mr-4 text-blue-500'

  return (
    <nav>
      <Link href="/" className={homeClass}>
        Home
      </Link>
      <Link href="/about" className={aboutClass}>
        About
      </Link>
      <Link href="/products/1" className={productClass}>
        Product 1
      </Link>
    </nav>
  )
}

8.编程式导航

tsx 复制代码
'use client'

import { useRouter } from 'next/navigation'

const About = () => {
  const router = useRouter()

  return (
    <div>
      <h2>About pages</h2>
      <button
        onClick={() => router.push('/')}
        className="bg-blue-500 text-white p-2 rounded-md"
      >
        Go Home
      </button>
    </div>
  )
}

export default About

9.新方式构建构建 API 端点

参考这篇:Nextjs15 构建API端点

相关推荐
遇见~未来14 分钟前
JavaScript数组全解析:从本质到高级技巧
开发语言·前端·javascript
石像鬼₧魂石18 分钟前
80 端口(Web 服务)渗透测试完整总结(含踩坑 + 绕过 + 实战流程)
linux·运维·服务器·前端·网络·阿里云
C_心欲无痕42 分钟前
nginx - 核心概念
运维·前端·nginx
开开心心_Every1 小时前
安卓做菜APP:家常菜谱详细步骤无广简洁
服务器·前端·python·学习·edge·django·powerpoint
前端_Danny1 小时前
用 ECharts markLine 实现节假日标注
前端·信息可视化·echarts
古城小栈1 小时前
Rust 丰富&好用的 格式化语法
前端·算法·rust
丢,捞仔1 小时前
uni-app上架应用添加权限提示框
前端·javascript·uni-app
Glink1 小时前
从零开始编写自己的AI账单Agent
前端·agent·ai编程
Hilaku1 小时前
我是如何用一行 JS 代码,让你的浏览器内存瞬间崩溃的?
前端·javascript·node.js
努力犯错玩AI1 小时前
如何在ComfyUI中使用Qwen-Image-Layered GGUF:完整安装和使用指南
前端·人工智能