@termit84

Как при клике на кнопку изменить класс другого элемента и текст самой кнопки?

Добрый день, помогите немного модифицировать решение которое я нашел.

Нужно вместо изменения STYLE чтобы у контейнера добавлялся/удалялся класс, например ACTIVE

<button class="js-button" data-toggle-text="Close">Open</button>
<div class="js-container hidden">
Some text here.
</div>
		
<script>
;(function($D){
    var $button    = $D.querySelector('.js-button'),
        $container = $D.querySelector('.js-container');
  
    $button.addEventListener('click', function(e){
      var data = e.target.dataset,
          toggleText = $button.innerHTML,
          isVisible = $container.style.display == 'block';
      
      $button.innerHTML = data.toggleText;
      data.toggleText = toggleText;
      
      $container.style.display = isVisible ? 'none' : 'block';
    });
})(document);
</script>
  • Вопрос задан
  • 1164 просмотра
Решения вопроса 1
carlcox
@carlcox
Fullstack developer
;(function($D){
    var $button    = $D.querySelector('.js-button'),
        $container = $D.querySelector('.js-container');
  
    $button.addEventListener('click', function(e){
      var data = e.target.dataset,
          toggleText = $button.innerHTML,
          isVisible = $container.classList.contains('active') ? true : false
      
      $button.innerHTML = data.toggleText;
      data.toggleText = toggleText;      
      if(!isVisible){
        $container.classList.add('active')
      }else{
        $container.classList.remove('active')
      }      
       
    });
})(document);
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

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

Войти через центр авторизации
Похожие вопросы