您的位置:首页 > 健康 > 养生 > React@16.x(37)路由v5.x(2)路由信息

React@16.x(37)路由v5.x(2)路由信息

2024/10/6 18:23:24 来源:https://blog.csdn.net/qq_40147756/article/details/139757011  浏览:    关键词:React@16.x(37)路由v5.x(2)路由信息

目录

  • 1,路由信息
  • 2,注入的信息
    • 2.1,history
      • 为什么不直接使用 window.history
    • 2.2,location
    • 2.3,match
      • 2.3.1,isExact
      • 2.3.2,params
  • 3,路由传参
    • 非路由组件获取路由信息

1,路由信息

Router 组件会创建一个上下文,并且向上下文中注入一些信息(该信息对开发者是隐藏的)。

Route 组件匹配到了路径,则会将这些上下文信息作为 props 传入对应的组件。

function A(props) {console.log(props);return <h1>A组件</h1>;
}
function B() {return <h1>B组件</h1>;
}export default function App() {return (<Router><Route path="/a" component={A}></Route><Route path="/b" component={B}></Route></Router>);
}

当访问 http://localhost:5173/a 会输出:

在这里插入图片描述

2,注入的信息

2.1,history

并不是 window.history 对象。主要利用 history 来实现无刷新跳转路由。

function A(props) {console.log(props);return (<h1onClick={() => {props.history.push("/b");}}>跳转路由/b</h1>);
}

push 也可以直接传递 search 参数:会从当前地址,跳转到带参数的地址。

props.history.push("?a=c");

其他的方法 replacegoforwardback 不多赘述。

为什么不直接使用 window.history

  1. React-router 支持2种路由模式(HashHistory),使用 React 自己的语法,可以无视路由模式来跳转。而 window.history不支持 Hash 模式。
  2. window.history.pushState 等方法的跳转,React 无法感应到地址变化,所以无法重新渲染页面。

2.2,location

和上面的 history.location 是同一个对象,放到外层更方便使用。

props.history.location === props.location // true

该对象记录了当前地址的相关信息,不过一般不使用它。如果要解析地址栏的数据,会用第3方库比如 query-string。

2.3,match

重点

该对象保存了,匹配路由的相关信息。几个重要的属性:

2.3.1,isExact

当前路径和路由配置的路径,是否完全匹配。比如:

<Route path="/a" component={A}></Route>
  • 当访问 /aisExact: true,(此时 Route.exact = false
  • 当访问 /a/b/cisExact: false

注意区分和 Route 组件中的 exact,它们并没有直接关系。

2.3.2,params

获取路径规则中对应的数据。

在使用 Route.path 属性时,除了直接写路径外,还可以写一个 string pattern字符串正则):

<Route path="/a/:id" component={A}></Route>

此时,只有访问 /a/xxx 时才会匹配到 A 组件。

在这里插入图片描述

  1. 多个参数
path="/news/:year/:month/:day"

则路径必须是 /news/xx/xx/xx 才能匹配到对应路由。

  1. 可选参数
path="/news/:year?/:month/:day"

则路径必须是 /news/xx/xx/xx/news/xx/xx

  1. 直接写正则,参数必须是数字。
path="/news/:year(\d+)/:month(\d+)/:day(\d+)"

则路径必须是 /news/11/22/33

  1. 通配符
path="/news/:year(\d+)/*"

则路径必须是 /news/11/xx。这个 xx 必须存在,可以是任意合法字符。

  1. 分隔符不一定非得是 /
path="/news-:year=:month"

则路径必须是 /news-xx=xx,比如 /news-12=34

在这里插入图片描述

react-router 使用了第3方库 path-to-regexp 来将字符串正则 转换为真正的正则表达式。

3,路由传参

下面4种方式,刷新页面数据都不会丢失。

  1. history.push(),第2个参数可传参,可在 location.state 中获取数据。

  2. search 传参,通过第3方库 query-string 获取数据。

  3. hash 传参,同样可使用 query-string 获取数据。

  4. params 传参,可在 match.params 中获取数据。

非路由组件获取路由信息

文章一开始就说了,只有当 Route 组件匹配到了路径,对应的组件才会有路由的上下文信息。

那非路由组件如何获取这些信息?

  1. 将路由信息,一层层传递下去。
  2. 使用 React-router 提供的高阶组件 withRouter。将目标组件传递,它会返回一个新组件,新组件将向目标组件注入路由信息。

路由的上下文信息,对开发者是隐藏的。而在 React-router 自己提组件 withRouter 中是可以获取的。

import { BrowserRouter as Router, Route, withRouter } from "react-router-dom";function A() {return (<><h1>A组件</h1><B /></>);
}
function B() {return (<><h1>B组件</h1><CWrapper /></>);
}function C(props) {console.log(props);return <h1>C组件</h1>;
}const CWrapper = withRouter(C);export default function App() {return (<Router><Route path="/a" component={A}></Route></Router>);
}

注意,withRouter 的组件参数,必须是 Router 组件的子元素,这样才能获取到路由的上下文信息注入到目标组件中。比如 React路由守卫实现 时就遇到了这样的问题。


以上。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com