如何去除 Material UI 的 DatePicker 的边框?

How to remove border of Material UI's DatePicker?

这是日期选择器组件

import React, { Fragment, useState } from "react";
import {
  KeyboardDatePicker,
  MuiPickersUtilsProvider
} from "@material-ui/pickers";
import DateFnsUtils from "@date-io/date-fns";
import makeStyles from "@material-ui/styles/makeStyles";

const useStyles = makeStyles({
  root: {
    "& .MuiInputBase-root": {
      padding: 0, 
      "& .MuiButtonBase-root": {
        padding: 0,
        paddingLeft: 10
      },
      "& .MuiInputBase-input": {
        padding: 15,
        paddingLeft: 0
      }
    }
  }
});

function InlineDatePickerDemo(props) {
  const [selectedDate, handleDateChange] = useState(new Date());
  const classes = useStyles();

  return (
    <MuiPickersUtilsProvider utils={DateFnsUtils}>
      <KeyboardDatePicker
        className={classes.root}
        autoOk
        variant="inline"
        inputVariant="outlined"
        label="With keyboard"
        format="MM/dd/yyyy"
        value={selectedDate}
       InputAdornmentProps={{ position: "start" }}
        onChange={(date) => handleDateChange(date)}
      />
    </MuiPickersUtilsProvider>
  );
}

export default InlineDatePickerDemo;

来自 codeSandbox Link 有谁能告诉我如何去除所有边的边框吗? 虽然我设法知道 .MuiInput-underline:before style class 负责边框宽度,但不知道将 class 放在 makeStyles.

的什么位置

只需要删除inputVariant="outlined"道具。所以你的代码变成:

<KeyboardDatePicker
    className={classes.root}
    autoOk
    variant="inline"
    label="With keyboard"
    format="MM/dd/yyyy"
    value={selectedDate}
    InputAdornmentProps={{ position: "start" }}
    onChange={(date) => handleDateChange(date)}
  />

Here 您的代码已修改。

const useStyles = makeStyles({
  root: {
    "& .MuiInputBase-root": {
      padding: 0,
      "& .MuiButtonBase-root": {
        padding: 0,
        paddingLeft: 10,
      },
      "& .MuiInputBase-input": {
        padding: 15,
        paddingLeft: 0
      },
      "& .MuiOutlinedInput-notchedOutline": {
        border: 'none'
      }
    }
  }
});

您只需稍微编辑一下 KeyboardDatePicker 元素:

  1. 删除inputVariant="outlined"

  2. 添加

InputProps={{
  disableUnderline: true
}}

CodeSandbox

在 MUI 中,您可以将 variant="standard" 添加到 TextField 中:

 renderInput={(params) => <TextField variant="standard" {...params} />}

完全 :

 <DesktopDatePicker
                inputFormat="MM/dd/yyyy"
                className="mt-0 w-100"
                required={required}
                margin="normal"
                id="date-picker-dialog"
                label={label}
                format="dd/MM/yyyy"
                value={value}
                onChange={handleDateChange}
                renderInput={(params) => <TextField variant="standard" {...params} />}
            />