Задать вопрос
@Kipsi

Как в react можно добавлять классы на элементы?

В js можно добавлять классы используя например

const header = document.querySelector(`.header`);
  if (условие) {
      header.classList.add(`active`);
  }

А как в react'e можно делать подобное кроме как через

const box = props => {
  const deff = ['deff']
    if (props.name !== '') {
      deff.push('metal')
    } else {
      deff.push('energ')
    }
 
   return (
     <input
        className={deff.join(' ')}
      />
   )
}

Можно ли в нем тоже использовать classList.add или querySelector например?
  • Вопрос задан
  • 3303 просмотра
Подписаться 1 Простой 1 комментарий
Решения вопроса 2
@Che603000
c 2011 javascript
Обычно используют https://www.npmjs.com/package/classnames

В Вашем случае:
const classNames = require('classnames');

const box = props => {

  const inputClass = classNames('deff', {
        metal:  props.name,
        energ: !props.name
   });

   return  <input className={inputClass} />;
}
Ответ написан
Комментировать
RomReed
@RomReed
JavaScript, Flutter, ReactNative, Redux, Firebase
return (
     <input
        className={props.name !== ''?'deff  metal':' deff  energ'}
      />
   )
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы