React-路由导航

1.声明式路由导航

1.1概念

说明:声明式导航是指通过在模版中通过<Link/>组件描述出要跳转到哪里去,比如后台管理系统的左侧菜单通常使用这种方式进行。

javascript 复制代码
import {Link} from "react-router-dom"
const Login=()=>{
    return (
        <div>我是登录页面
            <Link to={"/home"}>跳转Home页</Link>
        </div>
    )
}
export default  Login

1.2传参

1.2.1 Login页面

javascript 复制代码
 <button onClick={()=>navigation("/home/1/forever")}>跳转Home页(params传参)</button>

1.2.2路由path配置

javascript 复制代码
import Login from "../page/Login";
import Home from "../page/Home";


import {createBrowserRouter} from "react-router-dom"


const router=createBrowserRouter([
    {
        path:"/login",
        element:<Login></Login>
    },
    {
        path:"/home/:id/:username",
        element:<Home></Home>
    }
]
)

export default router

1.2.3参数获取

javascript 复制代码
import { useParams } from "react-router-dom"

const Home=()=>{
    // const [params]=useSearchParams()
    const params=useParams()
    return (
  <div>我是home页面id{params.id}
  <div>我是home页面username{params.username}</div>
  </div>

                       )
}
export default  Home

1.2.4页面

2.编程式路由导航

2.1概念

说明:编程式导航是指通过`useNavigate`钩子得到导航方法,然后通过调用方法以命令式的形式进行路由跳转,比如想在登录请求完毕之后跳转就可以选择这种方式,更加灵活。

javascript 复制代码
import {Link,useNavigate} from "react-router-dom"
const Login=()=>{
    const navigation=useNavigate()
    return (
        <div>我是登录页面
            {/* 声明式写法 */}
            <Link to={"/home"}>跳转Home页</Link>
            {/* 命令式写法 */}
            <button onClick={()=>navigation("/home")}>跳转Home页</button>
        </div>
    )
}
export default  Login

2.2传参

2.2.1Lgoin页面

javascript 复制代码
import {Link,useNavigate} from "react-router-dom"
const Login=()=>{
    const navigation=useNavigate()
    return (
        <div>我是登录页面
            {/* 声明式写法 */}
            <Link to={"/home"}>跳转Home页</Link>
            {/* 命令式写法 */}
            <button onClick={()=>navigation("/home")}>跳转Home页</button>
            <button onClick={()=>navigation("/home?id=1&&username=forever")}>跳转Home页(传参)</button>
        </div>
    )
}
export default  Login

2.2.2跳转效果

2.2.3参数获取

说明:home获取参数。

javascript 复制代码
import { useSearchParams } from "react-router-dom"

const Home=()=>{
    const [params]=useSearchParams()
    
    return (
    <div>我是home页面{params.get("id")}
    <div>我是home页面{params.get("username")}
        </div> 
        </div>)
}
export default  Home
相关推荐
小李小李不讲道理1 小时前
「Ant Design 组件库探索」五:Tabs组件
前端·react.js·ant design
毕设十刻1 小时前
基于Vue的学分预警系统98k51(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
mapbar_front2 小时前
在职场生存中如何做个不好惹的人
前端
牧杉-惊蛰2 小时前
纯flex布局来写瀑布流
前端·javascript·css
一袋米扛几楼983 小时前
【软件安全】什么是XSS(Cross-Site Scripting,跨站脚本)?
前端·安全·xss
向上的车轮4 小时前
Actix Web适合什么类型的Web应用?可以部署 Java 或 .NET 的应用程序?
java·前端·rust·.net
XiaoYu20024 小时前
第1章 核心竞争力和职业规划
前端·面试·程序员
excel4 小时前
🧩 深入浅出讲解:analyzeScriptBindings —— Vue 如何分析 <script> 里的变量绑定
前端
蓝瑟4 小时前
AI时代程序员如何高效提问与开发工作?
前端·ai编程
林晓lx4 小时前
使用Git钩子+ husky + lint语法检查提高前端项目代码质量
前端·git·gitlab·源代码管理