聚焦和不聚焦Material UI Input时无法更改边框颜色

时间:2020-04-22 13:38:05

标签: javascript reactjs material-ui

我不确定为什么无法使它正常工作。我正在选择MuiInputBase-root元素,告诉它选择字段并将边框颜色设置为蓝色,并在焦点上将边框颜色设置为红色。我在这里做什么错了?

Codesandbox

import React from "react";
import "./styles.css";

import { makeStyles } from "@material-ui/core/styles";
import FormControl from "@material-ui/core/FormControl";
import OutlinedInput from "@material-ui/core/OutlinedInput";
import InputLabel from "@material-ui/core/InputLabel";

const useStyles = makeStyles(theme => ({
  root: {
    width: "20rem"
  },
  label: {
    background: "white",
    paddingRight: theme.spacing(0.5),
    "&.Mui-focused": {
      color: theme.palette.secondary.main
    }
  },
  closeIcon: {
    color: theme.palette.grey[400],
    "&.hidden": {
      display: "none"
    }
  },
  searchIcon: {
    color: theme.palette.primary.main
  }
}));

const useOutlinedInputStyles = makeStyles({
  root: {
    "& .MuiInputBase-root": {
      "& fieldset": {
        borderColor: "blue"
      },
      "&.Mui-focused fieldset": {
        borderColor: "red"
      }
    }
  }
});

export default function App() {
  const classes = useStyles();
  const outlinedInputStyles = useOutlinedInputStyles();
  return (
    <div className="App">
      <FormControl className={classes.root} variant="outlined">
        <InputLabel className={classes.label} htmlFor="search-input">
          placeholder
        </InputLabel>
        <OutlinedInput
          classes={outlinedInputStyles}
          id="search-input"
          labelWidth={70}
        />
      </FormControl>
    </div>
  );
}

img

1 个答案:

答案 0 :(得分:1)

问题在于.MuiInputBase-root不是根元素(.MuiOutlinedInput-root元素)的子元素,它实际上是完全相同的元素,因此该层是不必要的。另外,类型选择器(例如fieldset)比类选择器具有lower specificity,因此&.Mui-focused fieldset的特异性不足以覆盖default focused styles。可以使用类选择器fieldset代替.MuiOutlinedInput-notchedOutline

所以代替:

root: {
  "& .MuiInputBase-root": {
    "& fieldset": {
      borderColor: "blue"
    },
    "&.Mui-focused fieldset": {
      borderColor: "red"
    }
  }
}

您应该具有:

  root: {
    "& .MuiOutlinedInput-notchedOutline": {
      borderColor: "blue"
    },
    "&.Mui-focused .MuiOutlinedInput-notchedOutline": {
      borderColor: "red"
    }
  }

Edit OutlinedInput border

相关答案:Change border color on Material-UI TextField