如何在材料 ui REACTjs 中覆盖 menuItem 中的选定类?

IT技术 css reactjs material-ui menuitem styling
2021-05-24 04:54:24

你好,我遇到了一个问题,我无法覆盖在选择菜单项时显示正确样式的类:这是我的代码:

       <MenuItem component={Link} to="/Acceuil" 
        className={{root:classes.menuItem ,selected:classes.selected}} 
           selected={pathname === "/Acceuil"} >
              <ListItemIcon>
                  <Icon className={classes.icon} >
                      insert_drive_file
                   </Icon>
               </ListItemIcon>
            Gestion Commandes
        </MenuItem>

这是类 const :

      Const classes = theme => ({
       menuItem: {
         fontStyle:'bold',
         backgroundColor: 'white',
         width: '88%',
      '&:active':{
        borderLeft: '4px solid #51bcda',
        backgroundColor: "-webkit-box-shadow: 6px 4px 53px -7px 
        rgba(0,0,0,0.75), -moz-box-shadow: 6px 4px 53px -7px 
        rgba(0,0,0,0.75),   box-shadow: 6px 4px 53px -7px 
        rgba(0,0,0,0.75),",
        },
       selected:{
       backgroundColor:'red !important' 
       } 
       });

谢谢你帮助我^^

1个回答

要了解如何以适当的特异性设置样式,您需要查看ListItem源代码MenuItem将其大部分样式委托给ListItem)。

以下是状态ListItem样式的相关部分selected

export const styles = theme => ({
  root: {
    '&$selected, &$selected:hover, &$selected:focus': {
      backgroundColor: theme.palette.action.selected,
    },
  },
  /* Styles applied to the root element if `selected={true}`. */
  selected: {},
});

下面我包含了一个覆盖所选 MenuItem 样式的示例,以及一个基于Selected menus demo的工作CodeSandbox

const styles = theme => ({
  menuItemRoot: {
    "&$menuItemSelected, &$menuItemSelected:focus, &$menuItemSelected:hover": {
      backgroundColor: "red"
    }
  },
  menuItemSelected: {}
});
...
            <MenuItem
              classes={{
                root: classes.menuItemRoot,
                selected: classes.menuItemSelected
              }}
...

编辑菜单选定的样式

这是不同 Material-UI 组件的类似问题/答案:React.js Material-UI 中的样式底部导航