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

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

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

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

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

//nav是顶层的路由组件
function Nav () {
  return (
    <>
      

欢迎来到Nav模块

该模块是导航模块,用来测试相关功能

{/* 下面是子组件的呈现地区,实际上就是vue的router-view */} ); }

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

function RouterTest () {
    const params1 = '参数一号准备就绪'
    const params2 = '参数二号准备就绪'
    
    return (
        <>
            

欢迎来到RouterTest模块

{/* 第一个普通link*/} ShowParams
{/* 第二个测试用的NavLink,这个因为是第二层级的Link,是不会激发active样式的 */} isActive ? "active" : "notActive"} to={`/routerTest/${params2}`} > NavLink1 {/* 因为有子路由,所以我们这边还得放一个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) => (
        
  • {brand.text}
  • )) return ( <>

    欢迎来到FilterLink

    该界面用来测试使用普通link组件传递active参数

    ) } // 定义一下高阶组件BrandLink function BrandLink ({ brand, children, ...props }) { let [searchParams] = useSearchParams() let isActive = searchParams.get("brand") === brand; return ( {children} ) }

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

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

    你可能感兴趣的:(react实践,react.js,前端,reactjs)