Передача стиля из состояния компонента в ReactJS - PullRequest
0 голосов
/ 19 ноября 2018

У меня есть следующий компонент:

import React from "react";
import { connect } from "react-redux";

class Filter extends React.Component {
  state = {
    value: ''
  };

  handleChange = (e) => {
    let value = e.target.value;
    if(value){
      document.getElementById("clear").style["display"] = "none";
      document.getElementById("fetch").style["display"] = "none";

    } else {
      document.getElementById("clear").style["display"] = "inline-block";
      document.getElementById("fetch").style["display"] = "inline-block";
    }
    this.setState({ value });
    this.props.handleFilter({ value });
  }

  render(){
  let content = this.props.items > 0 ? (
      <div
        className="filter"
        >
        <input
          id="search-input"
          type="text"
          placeholder="Search..."
          value={this.state.value}
          onChange={this.handleChange}
        />
      </div>
    ) : <div></div>
    return content;
  }
}

const mapStateToProps = (state,props) => ({
  items: state.settings.length
});

module.exports = connect(mapStateToProps, null)(Filter);

Можно ли как-нибудь изящнее передать реквизиты компонентам clear и fetch?Я пытаюсь стилизовать их, основываясь на взаимодействиях с моим поисковым вводом (в основном, я бы хотел иметь возможность стилизовать их, когда мое значение поиска равно ""). Как отправить стили в качестве реквизита в зависимости от состояния моего текущего компонента?

Ответы [ 2 ]

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

Пожалуйста, отреагируйте, что это именно то, что вы ищете: пожалуйста, найдите образец ниже:

import React, {
  Component
} from 'react'
import injectSheet from 'react-jss'
import classNames from 'classnames'


class someComponent extends Component {
  handleClose = () => {}

  render() {
    const {
      classes,
    } = this.props

    return ( <
      div className = {
        classes.resize
      } >
      <
      /div>
    )
  }
}


const styles = {
  container: {
    width: '100%',
    height: '100rem'
    borderBottom: '10px'
  }
}

export default injectSheet(styles)(someComponent)
0 голосов
/ 19 ноября 2018

Если вы используете библиотеку с именем styled-components, вы можете легко сделать это, как в этом примере: https://www.styled -components.com / docs / basics # pass-props .Идея с этой библиотекой заключается в том, что вы оборачиваете свои базовые компоненты HTML, такие как <input> до <Input>, а затем используете новый компонент <Input> в вашем методе render ().Новый компонент будет контролироваться путем передачи значений из вашего состояния в качестве реквизита.

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