[javascript] 순수 JavaScript에서 요소의 클래스를 어떻게 토글합니까?

이 jQuery 코드 (반응 형 메뉴 섹션에서 사용됨)를 순수 JavaScript로 변환하는 방법을 찾고 있습니다.

구현하기 어려운 경우 다른 JavaScript 프레임 워크를 사용해도됩니다.

$('.btn-navbar').click(function()
{
    $('.container-fluid:first').toggleClass('menu-hidden');
    $('#menu').toggleClass('hidden-phone');

    if (typeof masonryGallery != 'undefined')
        masonryGallery();
});



답변

2014 답변 : classList.toggle()표준이며 대부분의 브라우저에서 지원됩니다 .

이전 브라우저는 classList.toggle ()에 classlist.js를 사용할 수 있습니다 .

var menu = document.querySelector('.menu') // Using a class instead, see note below.
menu.classList.toggle('hidden-phone');

제쳐두고, 당신은 ID를 사용하지 않아야합니다 ( 그들은 전역을 JS window객체 로 유출 합니다 ).


답변

다음은 ES6로 구현 된 솔루션입니다.

const toggleClass = (el, className) => el.classList.toggle(className);

사용 예

toggleClass(document.querySelector('div.active'), 'active'); // The div container will not have the 'active' class anymore


답변

이 예제를보십시오 : JS Fiddle

function toggleClass(element, className){
    if (!element || !className){
        return;
    }

    var classString = element.className, nameIndex = classString.indexOf(className);
    if (nameIndex == -1) {
        classString += ' ' + className;
    }
    else {
        classString = classString.substr(0, nameIndex) + classString.substr(nameIndex+className.length);
    }
    element.className = classString;
}


답변

이것은 이전 버전의 IE에서도 작동합니다.

function toogleClass(ele, class1) {
  var classes = ele.className;
  var regex = new RegExp('\\b' + class1 + '\\b');
  var hasOne = classes.match(regex);
  class1 = class1.replace(/\s+/g, '');
  if (hasOne)
    ele.className = classes.replace(regex, '');
  else
    ele.className = classes + class1;
}
.red {
  background-color: red
}
div {
  width: 100px;
  height: 100px;
  margin-bottom: 10px;
  border: 1px solid black;
}
<div class="does red redAnother " onclick="toogleClass(this, 'red')"></div>

<div class="does collapse navbar-collapse " onclick="toogleClass(this, 'red')"></div>


답변

이것은 아마도 더 간결 할 것입니다.

function toggle(element, klass) {
  var classes = element.className.match(/\S+/g) || [],
      index = classes.indexOf(klass);

  index >= 0 ? classes.splice(index, 1) : classes.push(klass);
  element.className = classes.join(' ');
}


답변

이것을 시도하십시오 (잘 작동 할 것입니다) :

// mixin (functionality) for toggle class 
function hasClass(ele, clsName) {
    var el = ele.className;
    el = el.split(' ');
    if(el.indexOf(clsName) > -1){
        var cIndex = el.indexOf(clsName);
        el.splice(cIndex, 1);
        ele.className = " ";
        el.forEach(function(item, index){
          ele.className += " " + item;
        })
    }
    else {
        el.push(clsName);
        ele.className = " ";
        el.forEach(function(item, index){
          ele.className += " " + item;
        })
    }
}

// get all DOM element that we need for interactivity.

var btnNavbar =  document.getElementsByClassName('btn-navbar')[0];
var containerFluid =  document.querySelector('.container-fluid:first');
var menu = document.getElementById('menu');

// on button click job
btnNavbar.addEventListener('click', function(){
    hasClass(containerFluid, 'menu-hidden');
    hasClass(menu, 'hidden-phone');
})`enter code here`


답변

다음은 className에 split ( “”)을 사용하여 IE> = 9에 대한 코드입니다.

function toggleClass(element, className) {
    var arrayClass = element.className.split(" ");
    var index = arrayClass.indexOf(className);

    if (index === -1) {
        if (element.className !== "") {
            element.className += ' '
        }
        element.className += className;
    } else {
        arrayClass.splice(index, 1);
        element.className = "";
        for (var i = 0; i < arrayClass.length; i++) {
            element.className += arrayClass[i];
            if (i < arrayClass.length - 1) {
                element.className += " ";
            }
        }
    }
}