React·路由router (页面跳转)

React·路由router (页面跳转)

React·路由router

1】安装路由 npm add react-router-dom

2】导入路由

import { BrowserRouter, Link, Routes, Route } from "react-router-dom"

3】使用路由

 <BrowserRouter>
        <Link to='/'> 标签跳转 Aaa页路由 </Link>
        <Link to='/Bbb'>标签跳转 Bbb页路由 </Link>
        <Routes>
          <Route path="/" element={<AaaDiv></AaaDiv>}></Route>
          <Route path="/Bbb" element={<BbbDiv></BbbDiv>}></Route>
        </Routes>
 </BrowserRouter>

4】哈希路由 HashRouter

哈希路由使浏览器地址带#,刷新地址不跳转

import { HashRouter, Link, Routes, Route } from "react-router-dom" //导入路由 

//App.js  function App() {}里设置
<HashRouter>
        <Link to='/'> 标签跳转 Aaa页路由 </Link>
        <Link to='/Bbb'>  标签跳转 Bbb页路由 </Link>
        {/* 路由地址设置 */}
        <Routes>
          <Route path="/" element={<AaaDiv></AaaDiv>}></Route>
          <Route path="/Bbb" element={<BbbDiv></BbbDiv>}></Route>
        </Routes>
 </HashRouter>

5】api方式跳转

const navigate = useNavigate()
  function goAaa() {
    // navigate('/Bbb')
    navigate('/Bbb', { replace: true }) //replace禁止返回
  }

6】传参数 接参数

父级App.js 设置好路由地址

//import { HashRouter, Routes, Route } from "react-router-dom"
function App() {
    return (
        {/* 路由地址设置 */}
        <HashRouter>
            <Routes>
              <Route path="/" element={<AaaDiv></AaaDiv>}></Route>
              <Route path="/Bbb" element={<BbbDiv></BbbDiv>}></Route>
            </Routes>
             {/* 如果采用 params 模式 path="/Bbb:id" 用:打个参数配合*/}
        </HashRouter>
    )
}

带参数跳转

// import { useNavigate } from "react-router-dom"
// 路由跳转
    const navigate = useNavigate() //跳转涵
    function tapGo() {
        console.log("路由跳转")
        navigate('/Bbb?id=1001&name=ABC', { replace: true })
    }

接收参数

// import { useSearchParams } from "react-router-dom"
 const [parent] = useSearchParams() //格式固定 数组模式
    let id = parent.get('id')//地址 获取传参数
    let name = parent.get('name')//地址 获取传参数

    console.log('获取传参数:', id, name)

二级路由

在标签  <Route path="/"> 嵌套
如果 需要设置二级路由为默认 则  <Route 的 path="/" 改为 index > 
527 Views
分享你的喜爱
linwute
linwute

我要像梦一样自由,像大地一样宽容;
在艰辛放逐的路上,点亮生命的光芒;
我要像梦一样自由,像天空一样坚强;
在曲折蜿蜒的路上,体验生命的意义;

留下评论

您的邮箱地址不会被公开。 必填项已用 * 标注