请稍等 ...
×

采纳答案成功!

向帮助你的同学说点啥吧!感谢那些助人为乐的人

关于react-router-domV6,在class组件中可以使用useNavigate钩子么?

import React from "react";
import styles from "./Header.module.css";
import logo from "../../assets/logo.svg";
import { Layout, Typography, Input, Menu, Button, Dropdown } from "antd";
import { GlobalOutlined } from "@ant-design/icons";
import { useNavigate } from "react-router-dom";


export class Header extends React.Component {

  toPage = (val:string) => {
    const navigate = useNavigate();
    navigate(val)
  }

  render() {
    return (
      <div className={styles["app-header"]}>
        {/* top-header */}
        <div className={styles["top-header"]}>
          <div className={styles.inner}>
            <Typography.Text>让旅游更幸福</Typography.Text>
            <Dropdown.Button
              style={{ marginLeft: 15 }}
              overlay={
                <Menu>
                  <Menu.Item>中文</Menu.Item>
                  <Menu.Item>English</Menu.Item>
                </Menu>
              }
              icon={<GlobalOutlined />}
            >
              语言
            </Dropdown.Button>
            <Button.Group className={styles["button-group"]}>
              <Button onClick={()=>this.toPage('register')}>注册</Button>
              <Button>登陆</Button>
            </Button.Group>
          </div>
        </div>
        <Layout.Header className={styles["main-header"]}>
          <span>
            <img src={logo} alt="logo" className={styles["App-logo"]} />
            <Typography.Title level={3} className={styles.title}>
              React旅游网
            </Typography.Title>
          </span>
          <Input.Search
            placeholder={"请输入旅游目的地、主题、或关键字"}
            className={styles["search-input"]}
          />
        </Layout.Header>
        <Menu mode={"horizontal"} className={styles["main-menu"]}>
          <Menu.Item key={1}>旅游首页</Menu.Item>
          <Menu.Item key={2}>周末游</Menu.Item>
          <Menu.Item key={3}>跟团游</Menu.Item>
          <Menu.Item key="4"> 自由行 </Menu.Item>
		          <Menu.Item key="5"> 私家团 </Menu.Item>
		          <Menu.Item key="6"> 邮轮 </Menu.Item>
		          <Menu.Item key="7"> 酒店+景点 </Menu.Item>
		          <Menu.Item key="8"> 当地玩乐 </Menu.Item>
		          <Menu.Item key="9"> 主题游 </Menu.Item>
		          <Menu.Item key="10"> 定制游 </Menu.Item>
		          <Menu.Item key="11"> 游学 </Menu.Item>
		          <Menu.Item key="12"> 签证 </Menu.Item>
		          <Menu.Item key="13"> 企业游 </Menu.Item>
		          <Menu.Item key="14"> 高端游 </Menu.Item>
		          <Menu.Item key="15"> 爱玩户外 </Menu.Item>
		          <Menu.Item key="16"> 保险 </Menu.Item>
        </Menu>
      </div>
    );
  }
}

图片描述
点击报错

正在回答 回答被采纳积分+3

2回答

我很容易上手 2022-03-29 11:23:08

其实直接嵌套Link 标签就可以无缝修改为class组件了

<Button>

    <Link to={'/signIn'}>登录</Link>

</Button>

0 回复 有任何疑惑可以回复我~
阿莱克斯刘 2022-01-19 15:15:13

在class组件中需要包装一层HOC才能使用hook,但是使用函数式组件可以随意使用hook。函数式组件在后续课程中有详细介绍,课程会同时使用class和function两种组件来完成网站

0 回复 有任何疑惑可以回复我~
问题已解决,确定采纳
还有疑问,暂不采纳
意见反馈 帮助中心 APP下载
官方微信