码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • React@16.x(38)路由v5.x(3)其他组件


    目录

    • 1,Link
    • 2,NavLink
    • 3,Redirect

    之前的文章中,已经介绍过了 BrowserRouter / HashRouter,Route,Switch,withRouter 这些组件。

    再介绍3个常用的组件:

    1,Link

    官方文档

    生成一个无刷新跳转的 元素。

    主要的属性:

    1. to
      • 字符串,表示跳转的路径
      • 对象,属性和 history.location 的属性相同。
    2. replace,表示跳转时是否替换当前地址,默认 false。
    3. innerRef,可以将 Link 内部的 元素的 ref 附着到传递的对象或函数上。

    无刷新跳转的大致原理:

    import { withRouter } from "react-router-dom";
    
    function Link(props) {
        return (
            <a
                href={props.to}
                onClick={(e) => {
                    e.preventDefault();
                    props.replace ? props.history.replace(props.to) : props.history.push(props.to);
                }}
            >
                {props.children}
            </a>
        );
    }
    
    export default withRouter(Link);
    

    node 就是 a 元素。
    innerRef={node => { console.log(node)}}

    2,NavLink

    官方文档

    在 Link 的基础上实现的,并添加了额外的功能:

    当 to 匹配到当前路径时,会对生成的 元素添加对应的类名或样式,来表示激活状态。

    举例:

    <NavLink to="/b">跳转bNavLink>
    

    如果当前的路由路径是匹配到 /b 的(/b、/b/c 等),则 会给对应的 元素添加 class="active",这样就可以设置激活状态的 元素的样式了。

    生成的 元素

    <a aria-current="page" class="active" href="/b">跳转ba>
    

    主要的属性:

    1. activeClassName,匹配时的类名,默认 active。
    2. activeStyle,匹配时的样式,可以直接写内联样式。
    3. exact,sensitive 和 Route 组件对应的属性的含义一致。

    3,Redirect

    官方文档

    重定向组件,当加载到该组件时,会自动无刷新的跳转到指定的地址。

    举例1:除了 /a 或 /b,其他任何路径都会重定向到 /a:

    <Router>
        <Switch>
            <Route path="/a" component={A}>Route>
            <Route path="/b" component={B}>Route>
            <Redirect to="/a">重定向到 /aRedirect>
        Switch>
    Router>
    

    举例2:当访问根路径时,登录状态则重定向到 /dashboard,否则渲染 组件

    <Route exact path="/">
      {loggedIn ? <Redirect to="/dashboard" /> : <PublicHomePage />}
    Route>
    

    主要的属性:

    1. to,表示要重定向的路径。字符串或对象,和 的 to 属性一样。
    2. push,表示重定向跳转是 push | repalce,默认 false。
    3. from,表示匹配到 from 对应的路径规则,才会进行跳转到 to。
    4. exact,是否精确匹配 from。
    5. sensitive,匹配 from 时是否对大小写敏感。

    to 和 from 都可以写正则表达式,和 一样。

    举例3:

    <Redirect from="/c/:id" to="/a">重定向到 /aRedirect>
    

    当匹配到 /c/xxx 时,才会跳转到 /a

    举例4:

    <Redirect from="/c/:id" to="/a/:id">重定向到 /aRedirect>
    

    当匹配到 /c/xxx 时,会跳转到 /a/xxx。


    以上。

  • 相关阅读:
    基于springboot在线考试报名系统毕业设计源码031706
    Spring Security概述快速入门
    MyBatisPlus详解(二)条件构造器Wrapper、自定义SQL、Service接口
    Mock使用场景
    Springboot结合Mockito写单元测试实践和原理
    计算机学院改考后,网络空间安全学院也改考了!南京理工大学计算机考研
    网络安全学习--入侵检测和紧急响应
    【React-Hooks进阶】useState回调函数的参数 / useEffect发送网络请求/ useRef / useContext
    以太坊之使用truflle和infura部署以太坊合约|猿创征文
    亚马逊自养号测评安全吗?
  • 原文地址:https://blog.csdn.net/qq_40147756/article/details/139815140
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号