我一直在努力实现简单的事情。我试图<TreeMenu/>
用伪选择器在材质 UI v1 中显示/隐藏我的组件,但不知何故它不起作用。这是代码:CSS:
root: {
backgroundColor: 'white',
'&:hover': {
backgroundColor: '#99f',
},
},
hoverEle: {
visibility: 'hidden',
'&:hover': {
visibility: 'inherit',
},
},
rootListItem: {
backgroundColor: 'white',
display: 'none',
'&:hover': {
display: 'block',
backgroundColor: '#99f',
},
},
'@global': {
'li > div.nth-of-type(1)': {
display: 'block !important',
backgroundColor: "'yellow',",
},
},
根 css 类在列表上工作正常,但 rootListItem 甚至 @global li 选择器不起作用。我不确定我在选择器方面做错了什么。我阅读了 material-ui 文档并说 V1 支持伪选择器。
JSX:
<div>
{props.treeNode.map(node => (
<ListItem
key={`${node.Type}|${node.NodeID}`}
id={`${node.Type}|${node.NodeID}`}
className={(classes.nested, classes.root)}
button
divider
disableGutters={false}
dense
onClick={() => props.onNodeClick(node.Type, node.NodeID, node.NodeName)}
title={props.adminUser ? node.NodeID : ''}
onMouseOver={() => props.onMouseOver(node.Type, node.NodeID)}
>
<ListItemIcon>{props.listIcon}</ListItemIcon>
<ListItemText primary={node.NodeName} />
<ListItemSecondaryAction classes={{ root: classes.rootListItem }}>
<TreeMenu />
</ListItemSecondaryAction>
<div className={classes.hoverEle}>
<TreeMenu />
</div>
</ListItem>
))}
</div>
请查看<TreeMenu >
组件。我应用了 3 种不同的技巧:1) 带有'&:hover'
选择器的hoverEle 类。2) 试图<ListItemSecondaryAction>
用我的类覆盖默认的根类rootListItem
3) 在 li.See 上使用其他伪选择器 'li > div.nth-of-type(1)':