更改 MuiCheckbox 材质 UI 中的刻度颜色
IT技术
reactjs
material-ui
2021-04-25 22:24:07
3个回答
下面是一种似乎有效的方法。该方法的要点是创建一个框(通过:after伪元素),该框比检查图标略小,并具有所需的颜色作为背景颜色。然后将该框放在“已选中”图标后面。
import React from "react";
import { withStyles } from "@material-ui/core/styles";
import FormGroup from "@material-ui/core/FormGroup";
import FormControlLabel from "@material-ui/core/FormControlLabel";
import Checkbox from "@material-ui/core/Checkbox";
const CheckboxWithGreenCheck = withStyles({
root: {
"&$checked": {
"& .MuiIconButton-label": {
position: "relative",
zIndex: 0
},
"& .MuiIconButton-label:after": {
content: '""',
left: 4,
top: 4,
height: 15,
width: 15,
position: "absolute",
backgroundColor: "lightgreen",
zIndex: -1
}
}
},
checked: {}
})(Checkbox);
export default function CheckboxLabels() {
const [state, setState] = React.useState({
checkedA: true,
checkedB: false
});
const handleChange = name => event => {
setState({ ...state, [name]: event.target.checked });
};
return (
<FormGroup>
<FormControlLabel
control={
<CheckboxWithGreenCheck
checked={state.checkedA}
onChange={handleChange("checkedA")}
value="checkedA"
color="primary"
/>
}
label="Custom check color"
/>
</FormGroup>
);
}
另一种方法是创建一个包含支票所需颜色的自定义图标,然后通过checkedIcon属性使用它,如演示中的自定义图标示例所示。
刻度线实际上没有颜色设置。默认情况下,它采用背景的颜色。
您可以将复选框包装在 div 中,在其上放置背景颜色,div并且刻度线应该是彩色的。
如果您只想更改刻度线颜色,则必须使用以下技术。这是上面@Ryan 的增强版。
import React from "react";
import { withStyles } from "@material-ui/core/styles";
import FormGroup from "@material-ui/core/FormGroup";
import FormControlLabel from "@material-ui/core/FormControlLabel";
import Checkbox from "@material-ui/core/Checkbox";
const CheckboxWithGreenCheck = withStyles({
root: {
"& .MuiSvgIcon-root": {
fill: "white",
"&:hover": {
backgroundColor: "white"
}
},
"&$checked": {
"& .MuiIconButton-label": {
position: "relative",
zIndex: 0,
border: "1px solid #bbbbbb",
borderRadius: 3
},
"& .MuiIconButton-label:after": {
content: '""',
left: 4,
top: 4,
height: 15,
width: 15,
position: "absolute",
backgroundColor: "green",
zIndex: -1,
borderColor: "transparent"
}
},
"&:not($checked) .MuiIconButton-label": {
position: "relative",
zIndex: 0,
border: "1px solid #bbbbbb",
borderRadius: 3
},
"&:not($checked) .MuiIconButton-label:after": {
content: '""',
left: 4,
top: 4,
height: 15,
width: 15,
position: "absolute",
backgroundColor: "white",
zIndex: -1,
borderColor: "transparent"
}
},
checked: {}
})(Checkbox);
export default function CheckboxLabels() {
const [state, setState] = React.useState({
checkedA: true,
checkedB: false
});
const handleChange = (name) => (event) => {
setState({ ...state, [name]: event.target.checked });
};
return (
<FormGroup>
<FormControlLabel
control={
<CheckboxWithGreenCheck
checked={state.checkedA}
onChange={handleChange("checkedA")}
value="checkedA"
/>
}
label="Custom check color"
/>
</FormGroup>
);
}
https://codesandbox.io/s/checkbox-custom-check-color-forked-k3kw2?file=/demo.js
其它你可能感兴趣的问题