本人菜鸟,是按照文档进行学习的,今遇到两个小坑,现记录如下:
第一点,当前版本的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类的样式,所以不能正常工作。
以上是我的实验所得,本人初学,可能有错误理解,不过在我的实验之中确实呈现的是这个结果
|