React - 一般组件 withRouter 的使用(让一般组件具备路由组件特有的API属性)

这篇博客介绍了React中的withRouter高阶组件,它可以让普通组件获取到路由的history, location和match属性。通过withRouter包裹组件,实例中展示了如何在Header组件中实现回退、前进和指定步数跳转的功能,从而实现对路由的控制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

React - 一般组件 withRouter 的使用(让一般组件具备路由组件特有的API属性)

一. withRouter 理解

  1. withRouter 可以加工一般组件,让一般组件具备路由组件特有的 API 属性,会将historylocationmatch属性放到这个组件的props属性中。
  2. withRouter的返回值是一个新组件。

二. withRouter 使用

import React, { Component } from "react";
// 引入 withRouter
import { withRouter } from "react-router-dom";

class Header extends Component {
  // 回退
  back = () => {
    this.props.history.goBack();
  };

  // 前进
  forward = () => {
    this.props.history.goForward();
  };

  // 向前或向后跳转制定步数
  go = (num) => {
    this.props.history.go(num);
  };
  
  render() {
    console.log(123,this.props);
    return (
      <div className="page-header">
        <h2>导航栏</h2>
        <button onClick={this.back}>回退</button>&nbsp;
        <button onClick={this.forward}>前进</button>&nbsp;
        <button onClick={() => this.go(2)}>前进2</button>&nbsp;
        <button onClick={() => this.go(-2)}>后退2</button>
      </div>
    );
  }
}
// withRouter 包裹 Header 组件
export default withRouter(Header);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值