首页 > 解决方案 > Material UI Input 的焦点和不焦点时无法更改边框颜色

问题描述

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

代码沙盒

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>
  );
}

图像

标签: javascriptreactjsmaterial-ui

解决方案


问题是.MuiInputBase-root不是根元素(.MuiOutlinedInput-root元素)的子元素,它实际上是完全相同的元素,因此该层是不必要的。此外,类型选择器(例如fieldset)的特异性低于类选择器,因此&.Mui-focused fieldset没有足够的特异性来覆盖默认的焦点样式。而不是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"
    }
  }

编辑 OutlinedInput 边框

相关答案:更改 Material-UI TextField 上的边框颜色


推荐阅读