Как изменить цвет границы Material-UI - PullRequest
0 голосов
/ 21 октября 2018

Кажется, я не могу понять, как изменить цвет контура выделенного варианта. Я посмотрел вокруг проблем с GitHub, и люди, похоже, указывают на использование свойства InputProps, но, похоже, это ничего не делает.This is the field Вот мой код в его текущем состоянии

import React from 'react';
import { withStyles } from '@material-ui/core/styles';
import TextField from '@material-ui/core/TextField';
import PropTypes from 'prop-types';

const styles = theme => ({
field: {
    marginLeft: theme.spacing.unit,
    marginRight: theme.spacing.unit,
    height: '30px !important'
},
});

class _Field extends React.Component {
      render() {
          const { classes, fieldProps } = this.props;
             return (
                <TextField
                {...fieldProps}
                label={this.props.label || "<Un-labeled>"}
                InputLabelProps={{ shrink: true }} // stop from animating.
                inputProps={{ className: classes.fieldInput }}
                className={classes.field}
                margin="dense"
               variant="outlined"
            />
        );
    }
}

_Field.propTypes = {
    label: PropTypes.string,
    fieldProps: PropTypes.object,
    classes: PropTypes.object.isRequired
}

export default withStyles(styles)(_Field);

Ответы [ 7 ]

0 голосов
/ 26 июля 2019

Я имею в виду, что Mui.TextField имеет 3 стиля: стандартный, заполненный, выделенный.Вышеупомянутое решение работает только в изложенном стиле

0 голосов
/ 01 августа 2019
  inputProps={{ style: { fontFamily: 'nunito', color: 'white'}}}

Inputprops работает путем стилизации введенных входных данных в текстовом поле, а также мы можем использовать className для пользовательской раскраски.

      const CssTextField = withStyles({
     root: {
    '& label.Mui-focused': {
     color: 'white',
      },
     '& .MuiInput-underline:after': {
      borderBottomColor: 'yellow',
     },
    '& .MuiOutlinedInput-root': {
     '& fieldset': {
     borderColor: 'white',
     },
     '&:hover fieldset': {
      borderColor: 'white',
       },
     '&.Mui-focused fieldset': {
       borderColor: 'yellow',
     },
     },
    },

Этот константный стиль работает с внешним зельем текстового поля...

Оформление внешней части пользовательского интерфейса материала было запрошено для изменения ...

0 голосов
/ 12 июля 2019

https://codesandbox.io/s/6rx8p

                      <CssTextField      

                       label="Username"

                       className="username"
                       name="username"
                       onChange={this.onChange}
                       type="text"
                       autoComplete="current-password"
                       margin="normal"
                       inputProps={{ style: { fontFamily: 'nunito', color: 'white'}}}

                    />

// объявляем const и добавляем стиль пользовательского интерфейса материала

const CssTextField = withStyles({
  root: {
   '& label.Mui-focused': {
    color: 'white',
   },
   '& .MuiInput-underline:after': {
    borderBottomColor: 'yellow',
   },
  '& .MuiOutlinedInput-root': {
    '& fieldset': {
      borderColor: 'white',
    },
    '&:hover fieldset': {
      borderColor: 'white',
    },
    '&.Mui-focused fieldset': {
      borderColor: 'yellow',
    },
  },
},

}) (TextField);

0 голосов
/ 01 мая 2019

Расширение ответа Петра .Вы также можете изменить все цвета событий без !important:

 cssOutlinedInput: {
        "&:not(hover):not($disabled):not($cssFocused):not($error) $notchedOutline": {
          borderColor: "red" //default      
        },
        "&:hover:not($disabled):not($cssFocused):not($error) $notchedOutline": {
          borderColor: "blue" //hovered
        },
        "&$cssFocused $notchedOutline": {
          borderColor: "purple" //focused
        }
      },
      notchedOutline: {},
      cssFocused: {},
      error: {},
      disabled: {}

https://stackblitz.com/edit/material-ui-custom-outline-color-c6zqxp

0 голосов
/ 29 марта 2019
const styles = theme => ({
  notchedOutline: {
    borderWidth: "1px",
    borderColor: "yellow !important"
  }
});

 <TextField
              variant="outlined"
              rows="10"
              fullWidth
              InputProps={{
                classes: {
                  notchedOutline: classes.notchedOutline
                }
              }}
              id="standard-textarea"
              label="Input Set"
              helperText="Enter an array with elemets seperated by , or enter a JSON object"
              placeholder="Placeholder"
              multiline
              value={"" + this.props.input}
              onChange={this.props.handleChangeValue("input")}
              className={classes.textField}
              margin="normal"
            />

enter image description here

0 голосов
/ 16 ноября 2018

Взгляните на это, я сделал небольшую демонстрацию:

https://stackblitz.com/edit/material-ui-custom-outline-color

Он меняет цвет границы по умолчанию и цвет метки TextField Material-UI, но сохраняет основнойцвет в фокусе.

Также, посмотрите на эту ссылку, она дала мне «идею»:

https://github.com/mui-org/material-ui/issues/13347

Если вы хотите изменить цвет, когдаОбратите внимание на эти примеры из документации:

https://material -ui.com / demos / text-fields / # custom-input

0 голосов
/ 21 октября 2018

Вы можете переопределить все имена классов, введенные Material-UI, благодаря свойству classes.Посмотрите на переопределение с классами section и реализацию компонента для более подробной информации.

и наконец:

APIдокументация компонента Input React.Узнайте больше о свойствах и точках настройки CSS.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...