React路由跳转Link和NavLink

一、路由跳转和路由嵌套。

问题描述: 在设置react路由时,有个非路由组件要和部分路由绑定显示,因此使用二级路由。但是v6版本Routers不支持嵌套非路由组件,因此报错!

import React, { Component } from 'react';
import { HashRouter, Route, Routes } from 'react-router-dom';

import Layout from '../pages/Main/Home/layout';

import Home from '../pages/Main/Home/index'
import LifeService from '../pages/Main/LifeService/index'
import Shop from '../pages/Main/Shop/index'
import User from '../pages/Main/User/index'
import BottomNav from '../components/BottomNav';
import City from '../pages/City/index'

const AppRouter = () => {
  return (
    <HashRouter>
      <Routes>
        <Route path='/city' element={<City />}></Route>
        <Layout path='/'>
          <BottomNav></BottomNav>
          <Routes>
            <Route path='/' element={<Home />}></Route>
            <Route path='/life' element={<LifeService />}></Route>
            <Route path='/shop' element={<Shop />}></Route>
            <Route path='/user' element={<User />}></Route>
          </Routes>
        </Layout>
        {/* <Route path='/*' element={<Layout/>}></Route> */}
      </Routes>
    </HashRouter>
  )
}

 解决方法: 将Layout封装成组件,通过来进行跳转,并配置path属性。

import React, { Component } from 'react';
import { HashRouter, Route, Routes } from 'react-router-dom';

import Layout from '../pages/Main/Home/layout';

// import Home from '../pages/Main/Home/index'
// import LifeService from '../pages/Main/LifeService/index'
// import Shop from '../pages/Main/Shop/index'
// import User from '../pages/Main/User/index'
// import BottomNav from '../components/BottomNav';
import City from '../pages/City/index'

export default class AppRouter extends Component {
  render() {
    return (
      <div>
        <HashRouter>
            <Routes>
                <Route path="/city" element={ <City></City> }></Route>
                <Route path="/*" element={ <Layout></Layout> }></Route>
            </Routes>
        </HashRouter>
      </div>
    );
  }
}
import React, { Component } from 'react';
import { Route, Routes } from 'react-router-dom';
import BottomNav from '../../../components/BottomNav'
import Home from '../../Main/Home'
import LifeService from '../../Main/LifeService'
import Shop from '../../Main/Shop'
import User from '../../Main/User'

export default class Layout extends Component {
  render() {
    return (
      <div>
        <BottomNav></BottomNav>
        <Routes>
          <Route exact path="/" element={ <Home></Home> }></Route>
          <Route path="/lifeService" element={ <LifeService></LifeService> }></Route>
          <Route path="/shop" element={ <Shop></Shop> }></Route>
          <Route path="/user" element={ <User></User> }></Route>
        </Routes>
      </div>
    );
  }
}

 注意!!!: v6版本的path为严格匹配,因此如果path=‘/‘则无法访问内部的二级路由,应采用path=’/*’,*通配符进行路由设置。

二、路由跳转的Link和NavLink的区别。

1.Link

我们开发网页应用需要在各个页面间切换,如果使用锚点元素实现,在每次点击时,页面被重新加载,React Router提供了<Link>组件用来避免这种状况发生。当你点击<Link>时,url会更新,组件会被重新渲染,但是页面不会重新加载。

// to为string
<Link to="/about">关于</Link>
 
// to为obj
<Link to={{
  pathname: '/courses',
  search: '?sort=name',
  hash: '#the-hash',
  state: { fromDashboard: true }
}}/>
 
// replace 
<Link to="/courses" replace />

<Link>使用to参数来描述需要定位的页面。它的值既可是字符串,也可以是location对象(包含pathname、search、hash、与state属性)如果其值为字符串,将会被转换为location对象。

replace(bool):为 true 时,点击链接后将使用新地址替换掉访问历史记录里面的原地址;为 false 时,点击链接后将在原有访问历史记录的基础上添加一个新的纪录,默认为 false。

点击Link组件后,React Router路由发生了什么?

        Link 组件最终会渲染为 HTML 标签 <a>,它的 to、query、hash 属性会被组合在一起并渲染为 href 属性。虽然 Link 被渲染为超链接,但在内部实现上使用脚本拦截了浏览器的默认行为,然后调用了history.pushState 方法(注意,文中出现的 history 指的是通过 history 包里面的 create*History 方法创建的对象,window.history 则指定浏览器原生的 history 对象,由于有些 API 相同,不要弄混)。history 包中底层的 pushState 方法支持传入两个参数 state 和 path,在函数体内有将这两个参数传输到 createLocation 方法中,返回 location 的结构如下:

location = {
  pathname, // 当前路径,即 Link 中的 to 属性
  search, // search
  hash, // hash
  state, // state 对象
  action, // location 类型,在点击 Link 时为 PUSH,浏览器前进后退时为 POP,调用replaceState 方法时为 REPLACE
  key, // 用于操作 sessionStorage 存取 state 对象
}

系统会将上述 location 对象作为参数传入到 TransitionTo 方法中,然后调用 window.location.hash 或者window.history.pushState() 修改了应用的 url,这取决于你创建 history 对象的方式,同时会触发history.listen中注册的事件监听器。

2、NavLink

<NavLink>是<Link>的一个特定版本,会在匹配上当前的url的时候给已经渲染的元素添加参数,组件的属性有:

  • activeClassName(string):设置选中样式,默认值为active
  • activeStyle(object):当元素被选中时,为此元素添加样式
  • exact(bool):为true时,只有当导致和完全匹配class和style才会应用
  • strict(bool):为true时,在确定为位置是否与当前URL匹配时,将考虑位置pathname后的斜线
  • isActive(func)判断链接是否激活的额外逻辑的功能
// activeClassName选中时样式为selected
<NavLink
  to="/faq"
  activeClassName="selected"
>FAQs</NavLink>
 
// 选中时样式为activeStyle的样式设置
<NavLink
  to="/faq"
  activeStyle={{
    fontWeight: 'bold',
    color: 'red'
   }}
>FAQs</NavLink>
 
// 当event id为奇数的时候,激活链接
const oddEvent = (match, location) => {
  if (!match) {
    return false
  }
  const eventID = parseInt(match.params.eventID)
  return !isNaN(eventID) && eventID % 2 === 1
}
 
<NavLink
  to="/events/123"
  isActive={oddEvent}
>Event 123</NavLink>

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值