MUI 中的 CSS 子选择器
IT技术
reactjs
material-ui
jss
2021-04-13 20:45:43
5个回答
根据@josh 的建议,使用 &
deleted: {
"& td": {
background: "red"
}
}
https://codesandbox.io/s/llmq5or1w7
import React from "react";
import PropTypes from "prop-types";
import { withStyles } from "@material-ui/core/styles";
import Table from "@material-ui/core/Table";
import TableBody from "@material-ui/core/TableBody";
import TableCell from "@material-ui/core/TableCell";
import TableHead from "@material-ui/core/TableHead";
import TableRow from "@material-ui/core/TableRow";
import Paper from "@material-ui/core/Paper";
const styles = theme => ({
root: {
width: "100%",
marginTop: theme.spacing.unit * 3,
overflowX: "auto"
},
table: {
minWidth: 700
},
deleted: {
"& td": {
background: "red"
}
}
});
let id = 0;
function createData(name, calories, fat, carbs, protein) {
id += 1;
return { id, name, calories, fat, carbs, protein };
}
const rows = [
createData("Frozen yoghurt", 159, 6.0, 24, 4.0),
createData("Ice cream sandwich", 237, 9.0, 37, 4.3),
createData("Eclair", 262, 16.0, 24, 6.0),
createData("Cupcake", 305, 3.7, 67, 4.3),
createData("Gingerbread", 356, 16.0, 49, 3.9)
];
function SimpleTable(props) {
const { classes } = props;
return (
<Paper className={classes.root}>
<Table className={classes.table}>
<TableHead>
<TableRow>
<TableCell>Dessert (100g serving)</TableCell>
<TableCell align="right">Calories</TableCell>
<TableCell align="right">Fat (g)</TableCell>
<TableCell align="right">Carbs (g)</TableCell>
<TableCell align="right">Protein (g)</TableCell>
</TableRow>
</TableHead>
<TableBody>
{rows.map(row => {
return (
<TableRow key={row.id} className={classes.deleted}>
<TableCell component="th" scope="row">
{row.name}
</TableCell>
<TableCell align="right">{row.calories}</TableCell>
<TableCell align="right">{row.fat}</TableCell>
<TableCell align="right">{row.carbs}</TableCell>
<TableCell align="right">{row.protein}</TableCell>
</TableRow>
);
})}
</TableBody>
</Table>
</Paper>
);
}
SimpleTable.propTypes = {
classes: PropTypes.object.isRequired
};
export default withStyles(styles)(SimpleTable);
如果你想选择所有的孩子,你可以使用:“& > *”,比如:
root: {
"& > *": {
...
}
},
...
},
以防万一有人在看,以下是您选择具有 data 属性的子项的方法:
...
root: {
"& span[data-index='0']": {
transform: 'translateX(-15%)',
},
"& span[data-index='3']": {
...
}
},
...
我正在寻找一种方式来设置 webkit 子选择器的样式。
audioPlayer: {
"&::-webkit-media-controls-play-button": {
}
}
离开是为了节省别人的时间!
import { Box, styled } from "@mui/material";
const StyledBox = styled(Box)({
// root selector (.MuiBox-root)
background: "red",
"&": {
// '&' points to the root selector which is the same as the above (.MuiBox-root)
background: "red"
},
"&&": {
// also a root selector but with higher CSS specificity (.MuiBox-root.MuiBox-root)
background: "red"
},
"& .ChildSelector": {
// child selector (.MuiBox-root .ChildSelector)
background: "orange",
// this '&' points to the current selector which is '.MuiBox-root .ChildSelector'
"& .NestedChildSelector": {
// nested child selector (.MuiBox-root .ChildSelector .NestedChildSelector) (#1)
background: "yellow"
}
},
"& .ChildSelector .NestedChildSelector": {
// same as (#1) (.MuiBox-root .ChildSelector .NestedChildSelector)
background: "yellow"
},
});
其它你可能感兴趣的问题