react跳转和传参两种方式

需要安装ReactRouter包:npm i react-router-dom

两种跳转方式分别是LinkuseNavigate,下面跳转传参会有所展示

1.useSearchParams传参

 传参代码

//传参方代码
import { Link, useNavigate } from "react-router-dom"
const Login = () =>{
    const navigate = useNavigate()
    return <div>
            <button onClick={()=>navigate('/shop?id=100&name=zs')}>登录(传参)</button>
            <Link to="/shop?id=100&name=zs">跳转到购物(传参)</Link>
    </div>
}
export default Login

接收代码 

//接收方代码
import { useSearchParams } from "react-router-dom"
function App(){
  // 接收传参
  const [params] = useSearchParams()
  const id = params.get('id')
  const name = params.get('name')
  console.log(id, '接收传参', name)
}

2.useParams传参

//路由这里需要进行配置(主要看my的配置)
import Login from '../view/login/index'
import My from '../view/my/index'
import { createBrowserRouter } from 'react-router-dom'

const router = createBrowserRouter([
    {
        path:'/login',
        element:<Login/>
    },
    {
        path:'/my/:id/:name',
        element:<My/>
    }
])

export default router

 传参代码

//传参方
import { Link, useNavigate } from "react-router-dom"


const Login = () =>{
    const navigate = useNavigate()
    return <div>
        <Link to="/my/100/ll">跳转到我的(传参)</Link>
    </div>
}
export default Login

接收代码

//接收方
import { useParams } from "react-router-dom"
const My = () =>{
    const params = useParams()
    const id = params.id
    const name = params.name
    return <div>
        <div>这里是我的页面,id是{id},名字是{name}</div>
    </div>
}
export default My

相关推荐

  1. react方式

    2023-12-31 13:16:03       58 阅读
  2. js的方式

    2023-12-31 13:16:03       30 阅读
  3. 关于ReactV18的页面接收

    2023-12-31 13:16:03       27 阅读
  4. vue路由(queryparams方式)

    2023-12-31 13:16:03       57 阅读
  5. Reactreact-router-dom路由导航的

    2023-12-31 13:16:03       63 阅读
  6. Flutter路由方式

    2023-12-31 13:16:03       35 阅读
  7. vue的

    2023-12-31 13:16:03       30 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-31 13:16:03       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-31 13:16:03       100 阅读
  3. 在Django里面运行非项目文件

    2023-12-31 13:16:03       82 阅读
  4. Python语言-面向对象

    2023-12-31 13:16:03       91 阅读

热门阅读

  1. ChatGPT怎么用?

    2023-12-31 13:16:03       67 阅读
  2. flask web学习之flask与http(三)

    2023-12-31 13:16:03       62 阅读
  3. Python字符串

    2023-12-31 13:16:03       64 阅读
  4. vue-mounted中处理data数据

    2023-12-31 13:16:03       49 阅读
  5. 数组|274. H 指数

    2023-12-31 13:16:03       63 阅读
  6. XXL-JOB学习笔记-基于注解实现自动注册新建任务

    2023-12-31 13:16:03       64 阅读
  7. Fine-Tuning Language Models from Human Preferences

    2023-12-31 13:16:03       48 阅读