• 技术文章 >web前端 >前端问答

    react路由有哪些常用组件

    青灯夜游青灯夜游2022-03-21 18:17:11原创580

    react路由常用组件有:1、BrowserRouter,设置路由模式为history;2、HashRouter,设置路由模式为hash;3、NavLink;4、Link;5、Redirect;6、Route;7、withRouter等等。

    本教程操作环境:Windows7系统、react17.0.1版、Dell G3电脑。

    React路由提供常用组件的详解

    组件及其作用:


    组件作用
    路由模式BrowserRouter约定模式 为 history,使用 HTML5 提供的 history API 来保持 UI 和 URL 的同步
    路由模式HashRouter约定模式 为 hash,使用 URL 的 hash 来保持 UI 和URL 的同步
    声明式跳转NavLink声明式跳转 还可以约定 路由激活状态
    声明式跳转Link声明式跳转 无激活状态
    重定向Redirect重定向 ~~ replace
    匹配并展示Route匹配组件,并展示组件。即匹配成功后,组件立即被替换成匹配的组件
    排他性匹配Switch排他性匹配。如果不想使用包容性,那么使用Switch。
    高阶组件withRouter把不是通过路由切换过来的组件中,将 history、location、match 三个对象传入props对象上(高阶组件)

    结构

    BrowserRouter

    属性类型作用
    basenamestring所有位置的基本URL。如果您的应用是从服务器上的子目录提供的,则需要将其设置为子目录。格式正确的基本名称应以斜杠开头,但不能以斜杠结尾
    getUserConfirmationFunction用于确认导航的功能。默认使用window.confirm

    Route

    属性类型作用
    pathstring |object路由匹配路径。没有path属性的Route 总是会 匹配
    exactboolean为true时,要求全路径匹配(/home)。路由默认为“包含”的(/和/home都匹配),这意味着多个 Route 可以同时进行匹配和渲染
    componentFunction |component在地址匹配的时候React的组件才会被渲染,route props也会随着一起被渲染
    renderFunction内联渲染和包装组件,要求要返回目标组件的调用

    Link

    属性类型作用
    tostring | 对象{pathname:,search:,hash:}要跳转的路径或地址
    replaceboolean是否替换历史记录

    NavLink

    属性类型作用
    tostring|对象{pathname:,search:,hash:}要跳转的路径或地址
    replaceboolean是否替换历史记录
    activeClassNamestring当元素被选中时,设置选中样式,默认值为 active
    activeStyleobject当元素被选中时,设置选中样式

    Switch

    该组件用来渲染匹配地址的第一个Route或者Redirect,仅渲染一个路由,排他性路由,默认全匹配(场景:侧边栏,引导选项卡等)

    属性类型作用
    locationstring object
    childrennode

    Redirect

    该组件用来渲染匹配地址的第一个Route或者Redirect,仅渲染一个路由,排他性路由,默认全匹配(场景:侧边栏和面包屑,引导选项卡等

    属性类型作用
    fromstring来自
    tostring object去向
    pushboolean添加历史记录
    exactboolean严格匹配
    sensitiveboolean区分大小写

    【相关推荐:Redis视频教程

    以上就是react路由有哪些常用组件的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:react 路由组件
    上一篇:react有哪些优缺点 下一篇:react新增加的生命周期有哪些
    VIP课程(WEB全栈开发)

    相关文章推荐

    • 【腾讯云】年中优惠,「专享618元」优惠券!• 简单常用技巧之React组件间通信(整理分享)• hooks怎么样,为什么vue和react都选择它!• 怎么配置VSCode,苏爽的调试Vue、React 代码!• VSCode插件分享:一个实时预览Vue/React组件的插件• 什么是hook?聊聊React中常用的两个Hook• 一文带你深入了解React Hooks!
    1/1

    PHP中文网