2016-04-18 17 views
1

オフキャンバスのサイドバーをトリガーするボタンがあります。オフキャンバスのサイドバーがアクティブな場合、メニューボタンはクリックできません。 そのため、私はクラス名 "js-off-canvas-exit"と "is-visible"を調べようとしています。メニューボタンはクラス名を "is-active"にする必要があります。そうでなければこのクラス名はメニューボタン。jquery:オブジェクトにクラス名を追加する

私の試みは次のようになります。

var menuButton = document.getElementById('menuButton'); 
    menuButton.addEventListener('click', function(e) { 
    menuButton.classList.toggle('is-active'); 
    e.preventDefault(); 
    }); 


    $('.js-off-canvas-exit .is-visible').click(function() { 
    menuButton.removeClass('is-active');// add classname is-active to menuButton 
    } 


    $('.js-off-canvas-exit:not(.is-visible)').click(function() { 
    menuButton.addClass('is-active');// remove classname is-active from menuButton 
    } 

誰かが私はこの作業を取得するために助けることができますか?

+0

'.js-off-canvas-exit .is-visible''を削除し、' '.js-off-canvas-exit.is-visible''を試してください –

答えて

0

menuButtonがネイティブDOM要素であるため、jQueryオブジェクトを作成する必要があります。 removeClass()addClass()のメソッドはDOM要素ではなくjQueryオブジェクトで使用できるためです。

$(menuButton).removeClass('is-active'); 

代わりの

menuButton.removeClass('is-active'); 

あなたはElement.classListオブジェクトのadd()remove()を使用することができます。

関連する問題