Подтвердить что ты не робот

Как добавить или удалить className в событии в ReactJS

Я совершенно новый для Реагировать, и я немного борюсь с преобразованием своего мышления из стандартных js.

В моем реагирующем компоненте у меня есть следующий элемент:

<div className='base-state' onClick={this.handleClick}>click here</div>

Поведение, которое я ищу, - это добавить дополнительный класс при нажатии. Моя первая идея заключалась в том, чтобы попытаться добавить класс в функцию обработчика кликов, например.

handleClick : function(e) {
   <add class "click-state" here>
}

Я не смог найти никаких примеров, которые бы делали что-либо подобное, поэтому я уверен, что я не думаю об этом правильно.

Может ли кто-нибудь указать мне в правильном направлении?

4b9b3361

Ответ 1

Список классов может быть получен из состояния компонента. Например:

var Component = React.createClass({
  getInitialState: function() {
    return {
      clicked: false
    };
  },

  handleClick: function() {
    this.setState({clicked: true});
  },

  render: function() {
    var className = this.state.clicked ? 'click-state' : 'base-state';
    return <div className={className} onClick={this.handleClick}>click here</div>;
  }
});

Вызов this.setState приведет к перезагрузке компонента.