javascript - 如何在ant design中自定义和更改菜单的颜色?

标签 javascript css reactjs menuitem antd

我目前正在使用reactJs 和ant design 来帮助我构建一个网站。然而,我偶然发现了一个问题。我可以更改菜单的实际颜色,但是当选择菜单项或鼠标悬停在菜单项上时,我无法更改菜单项的颜色。这是菜单,Menu Image我想将白色更改为浅绿色,但我还没有找到任何方法可以直接访问它并更改它。另外,我不想使用 LESS 来做到这一点。

有人知道如何解决这个问题吗?这是我的布局代码。

import { Layout, Menu, Icon, Row, Button, Col } from 'antd';
import React, { Component } from 'react'
import { BrowserRouter as Router, Route, Link } from "react-router-dom";


const { Header, Sider, Content } = Layout;
const { SubMenu } = Menu;

class BasicLayout extends React.Component {
  state = {
    collapsed: false,
    path: this.path
  };

  toggle = () => {
    this.setState({
      collapsed: !this.state.collapsed,
    });
  };

  render() {
    return (
      <Layout>
        <Sider className='ant-menu' trigger={null} collapsible collapsed={this.state.collapsed}>
          <div className="logo" />
          <Menu className='ant-menu' mode="inline" defaultSelectedKeys={['1']}>
            <Menu.Item key="1" >
              <Link to='/'>
                <Icon type="home" />
                <span>Home</span>
              </Link>
            </Menu.Item>
            <Menu.Item key="2">
              <Link to='/about'>
                <Icon type="plus" />
                <span>About</span>
              </Link>
            </Menu.Item>
            <SubMenu key="3" title={<span><Icon type="database" /><span>Directory</span></span>}>
                <Menu.Item>
                  <Link to='/resources/living'>
                    <span>Living Resources</span>
                  </Link>
                </Menu.Item>
                <Menu.Item>
                  <Link to='/water2'>
                    <span>Non-Living Resources</span>
                  </Link>
                </Menu.Item>
                <Menu.Item>
                  <Link to='/resources/recycle'>
                    <span>Recycling Resources</span>
                  </Link>
                </Menu.Item>

                <Menu.Item>
                  <Link to='/resources/reducing'>
                    <span>Reducing Resources</span>
                  </Link>
                </Menu.Item>
                <Menu.Item>
                  <Link to='/resources'>
                    <span>General</span>
                  </Link>
                </Menu.Item>
            </SubMenu>
          </Menu>
        </Sider>
        <Layout>
          <Header style={{ background: '#fff', padding: 0 }}>
            <Icon
              className="trigger"
              type={this.state.collapsed ? 'menu-unfold' : 'menu-fold'}
              onClick={this.toggle}
            />
          </Header>
          <Content
            style={{
              margin: '24px 16px',
              padding: 24,
              background: '#fff',
              minHeight: 280,
            }}
          >
            {this.props.children}
          </Content>
        </Layout>
      </Layout>
    );
  }
}
export default BasicLayout;

最佳答案

您需要将 Link 更改为 NavLink 并添加属性 activeClassName

<NavLink  to="/portoflio" activeClassName="your-active-class" className="link">Portoflio</NavLink>

对于悬停选项,您只能使用 css 来实现

a.link:hover {
  /*Any style you want to have link on mouse over*/
  background-color: yellow;
}
.your-active-class{
 /*Any style you want to have link that is active*/
 background-color: yellow;
 }

https://www.w3schools.com/cssref/sel_hover.asp

关于javascript - 如何在ant design中自定义和更改菜单的颜色?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58041379/

相关文章:

javascript - 如何在 Angular2 中创建具有动态内容的动态数量的 div?

html - 防止拖动绝对定位元素(iOS Safari)

html - 居中标题开始的左对齐列表项

javascript - 在 URL 查询更改后 react 如何呈现页面

reactjs - 无法将 firebase 导入到react.js 项目中。 "Module not found: Error: Package path . is not exported from package"

html - 在 ReactJS 上,我的 'root' div 并没有一直向上延伸。我怎样才能扩大它?

javascript - Angular 和 ngrx : problems during upgrading to version8

javascript - JSSOR: slider 无法在负载上正确缩放

php - 将 Canvas 图像保存到 mysql

javascript - 未在 javascript 中设置 Div 高度和宽度