React Router

一、简介

react router是一个构建基于react应用的路由管理库。允许你在程序中定义不同的路由和导航规则。以实现不同的url路径显示不同的组件。

二、相关技术

javascript 复制代码
<Router>
    <div>
        <ul id = "menu">
            <li><Link to = "/home">Home</Link></li>
            <li><Link to = "/hello">Hello</Link></li>
            <li><Link to = "/about">About</Link></li>
        </ul>
        
        <div id = "page-container">
            <Route path = "/home" component = {Home} />
            <Route path = "/hello" component = {Hello} />
            <Route path = "/about" component = {About} />
        </div>
    </div>
</Router>

Link实现导航跳转

Route 配置路由定义,对应组件会填充父组件。

React Router API

Link -> <Link to = '/about'>About</Link> 普通连接,不会触发浏览器刷新

NavLink -> <NavLink to = '/about' activieClassName = "selected">About</NavLink >

Prompt ->

javascript 复制代码
 <Prompt when = {fromIsHalfFilledOut}  message = "Are you sure you want to leave"/>

Redirect ->

javascript 复制代码
 <Route  exact path = "/" 
  render = {() => (loggedIn ? (<Redirect to "/dashboard"/>):
 (<PublicHomePage/>))} />

url传参

react 组件可以通过 match props 获取Route 中url对应的占位符值。

javascript 复制代码
// 通过match属性获取Route Path中的占位符值
const Topic = ({match}) => (
    <h1>Topic {match.params.id}</h1>
); 

export default class RouterParams extends React.PureComponent{
    render(){
        return (
            <Router>
                <div>
                    <ul id = "menu">
                        <li><Link to = '/topic/1'>Topic 1</Link></li>
                        <li><Link to = '/topic/2'>Topic 2</Link></li>
                        <li><Link to = '/topic/3'>Topic 3</Link></li>
                    </ul>
                    <div id = "page-container">
                        <Route path = "/topic/:id" component = {Topic} />
                    </div>
                </div>
            </Router>
        );
    
    }

}

默认情况下,直接修改浏览器地址是不会触发跳转的,必须通过Link或者其它React routeApi实现跳转。

嵌套路由

1.每个React组件都是路由容器。

2.React Router的声明式语法可以方便的定义嵌套路由。

举个多级目录嵌套路由例子

javascript 复制代码
// 一级目录
export const Category = () => {
    return () => {
        <Router>
            <div>
                <ul id = "menu">
                    <li><Link to = "/category/1">Category 1</Link></li>
                    <li><Link to = "/category/2">Category 2</Link></li>
                    <li><Link to = "/category/3">Category 3</Link></li>
                </ul>
                <div id = "nav-container">
                    <Route path = "/category/:id" component = {SubCategory}>
                </div>
            </div>
        </Router>
    }
}


// 二级目录
export const SecondCategory = ({match}) => {
    return () => {
        <Router>
         <div>
           <ul id = "menu">
             <li><Link to = "/category/${match.params.id}/sub/1">Category 1</Link></li>
             <li><Link to = "/category/${match.params.id}/sub/2">Category 2</Link></li>
             <li><Link to = "/category/${match.params.id}/sub/3">Category 3</Link></li>
           </ul>
           <div id = "page-container">
             <Route path = "/category/:id/sub/:subId" component = {Page}>
           </div>
         </div>            
        </Router>
    }
}


// 页面内容
export const Page = ({match}) =>{
    const data = getPageData(match.params.id, match.params.subid);
    return parseData(data);
}
相关推荐
视频砖家29 分钟前
移动端Html5播放器按钮变小的问题解决方法
前端·javascript·viewport功能
lyj1689971 小时前
vue-i18n+vscode+vue 多语言使用
前端·vue.js·vscode
小白变怪兽2 小时前
一、react18+项目初始化(vite)
前端·react.js
ai小鬼头2 小时前
AIStarter如何快速部署Stable Diffusion?**新手也能轻松上手的AI绘图
前端·后端·github
墨菲安全3 小时前
NPM组件 betsson 等窃取主机敏感信息
前端·npm·node.js·软件供应链安全·主机信息窃取·npm组件投毒
GISer_Jing3 小时前
Monorepo+Pnpm+Turborepo
前端·javascript·ecmascript
天涯学馆3 小时前
前端开发也能用 WebAssembly?这些场景超实用!
前端·javascript·面试
我在北京coding4 小时前
TypeError: Cannot read properties of undefined (reading ‘queryComponents‘)
前端·javascript·vue.js
前端开发与ui设计的老司机5 小时前
UI前端与数字孪生结合实践探索:智慧物流的货物追踪与配送优化
前端·ui
全能打工人5 小时前
前端查询条件加密传输方案(SM2加解密)
前端·sm2前端加密