react路由v6版本NavLink的两个小坑

本人新人,是按照文档进行学习的,今遇到两个小坑,现记录如下:

第一点,当前版本的NavLink的style或者className当中的isActive,不需要你对isActive进行任何操作,基本上照官网抄就可以了,会自动对isActive属性进行切换。在我看到相关文章中,好像在之前的版本中习惯使用内部的state对isActive进行true到false的转换。

当然,以上只是一个小问题,最重要的是第二点

第二点,NavLink现在的重点确实放在了nav上,按照我的实验,只有当NavLink组件放在用作“顶层导航”的时候,才能正常工作,也就是才能正常显示出你所配置的active的样式。以下是一段伪代码,用来解释什么是“顶层导航”

//nav是顶层的路由组件
function Nav () {
  return (
    <>
      <main>
        <h2>欢迎来到Nav模块</h2>
        <p>该模块是导航模块,用来测试相关功能</p>
      </main>
      <nav>
        {/* 通向Counter组件 */}
        <NavLink className={({ isActive }) => isActive ? "green" : "red"} to="/counter">Counter组件</NavLink>
        <br />
        {/* 通往路由测试页面 */}
        <NavLink className={({ isActive }) => isActive ? "green" : "red"} to='/routerTest'>routerTest</NavLink>
      </nav>
      {/* 下面是子组件的呈现地区,实际上就是vue的router-view */}
      <Outlet />
    </>
  );
}

以上是第一层级的组件,分别通向Counter和路由测试组件,这里面的NavLink就是第一层级的link导航,是能够正常工作的,能调动green的样式接下来再看Nav组件的“路由导航子组件”

function RouterTest () {
    const params1 = '参数一号准备就绪'
    const params2 = '参数二号准备就绪'
    
    return (
        <>
            <h1>欢迎来到RouterTest模块</h1>
            {/* 第一个普通link*/}
            <Link to={`/routerTest/${params1}`}>ShowParams</Link>
            <br />
            {/* 第二个测试用的NavLink,这个因为是第二层级的Link,是不会激发active样式的 */}
            <NavLink
                // className={({ isActive }) => isActive ? "active" : "notActive"}
                to={`/routerTest/${params2}`} >
                NavLink1
            </NavLink>
            {/* 因为有子路由,所以我们这边还得放一个Outlet */}
            <Outlet />
        </>
    )

}

RouterTests是一个子组件,里面的NavLink不是用来导航的顶层Link,所以不能调动active类的样式,所以不能正常工作。

以上是我的实验所得,本人初学,可能有错误理解,不过在我的实验之中确实呈现的是这个结果

以下是一个官网给的解决办法,实际上是通过对Link组件的包装实现的,代码如下:

import React from "react";
import { Link, useSearchParams } from "react-router-dom"
// 写一个外部数据
let brands = [{ id: 1, text: 'adidas' }, { id: 2, text: 'puma' }, { id: 3, text: 'nike' }]
export default function FilterLink () {
    let brandList = brands.map((brand) => (
        <li key={brand.id}>
            <BrandLink brand={brand.text}>{brand.text}</BrandLink>
        </li>
    ))
    return (
        <>
            <h1>欢迎来到FilterLink</h1>
            <p>该界面用来测试使用普通link组件传递active参数</p>
            <nav>
                <ul>
                    {brandList}
                </ul>
            </nav>
        </>
    )
}
// 定义一下高阶组件BrandLink
function BrandLink ({ brand, children, ...props }) {
    let [searchParams] = useSearchParams()
    let isActive = searchParams.get("brand") === brand;
    return (
        <Link to={`/page1/filterLink/?brand=${brand}`}
            {...props}
            style={{
                ...props.style,
                color: isActive ? "red" : "black",
            }}>{children}</Link>
    )
}

这个方法的原理就是在连接上带上搜索参数,然后用搜索参数和传入的brand值进行全等比较,然后激活样式。

所以说官网上细节还是挺全面的,常看常新,目前v6版本的路由官网好像还没有翻译,所以说英语也是要学滴。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值