本人新人,是按照文档进行学习的,今遇到两个小坑,现记录如下:
第一点,当前版本的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版本的路由官网好像还没有翻译,所以说英语也是要学滴。