如何在 aria true 或 false 时将 addClass 和 removeClass 添加到子元素?

How to addClass and removeClass to child element when aria true or false?

我使用的 dropdown button by Zurb Foundation 5 字体很棒,我的想法是在菜单可见时旋转字体,并在隐藏后将其旋转回来。

Zurb foundation 5 没有在元素上使用 class open 所以 hasClass 不起作用,而是使用 Aria 并且由于 hasAria 不存在我尝试使用一些遗憾的解决方案不要以一种或多种方式工作。我想要做的是在父元素 .wf-burgeraria-expanded = true 时将 class fa-rotate-90 添加到字体元素 <i> 并在 [=17] 时将其删除=].

这是我相当简单的 HTML 代码:

<h1>
    <a aria-expanded="false" aria-controls="drop1" data-dropdown="drop1" href="#" class="wf-burger">
        <i aria-hidden="true" class="fa fa-bars fa-rotate-90"></i>
    </a>
</h1> 
<ul aria-hidden="true" class="f-dropdown" id="drop1" data-dropdown-content>
    <li><a title="Link 1" href="#1">Link 1</a></li>
    <li><a title="Link 2" href="#2">Link 2</a></li>
    <li><a title="Link 3" href="#3">Link 3</a></li>
    <li><a title="Link 4" href="#4">Link 4</a></li>
    <li><a title="Link 5" href="#5">Link 5</a></li>
</ul>

此代码有效但不会删除 class 一旦咏叹调为假:

(function($) {
    var attr = $('.wf-burger').attr('aria-expanded');
    if (typeof attr !== typeof undefined && attr !== false) {
            $('.fa.fa-bars').addClass('fa-rotate-90');
    }
    if (typeof attr !== typeof undefined && attr !== true) {
        $('.fa.fa-bars').removeClass('fa-rotate-90');
    }
})(jQuery);

此代码根本不起作用:

(function($) {
    if ($('.wf-burger').attr('aria-expanded') === 'true') {
        $('.fa.fa-bars').addClass('fa-rotate-90');
    }
    if ($('.wf-burger').attr('aria-expanded') === 'false') {
        $('.fa.fa-bars').removeClass('fa-rotate-90');
    }
})(jQuery);

你可以用这个。您只需要使用 $('.wf-burger').attr('aria-expanded') == 'true'。无需使用类型检查 ===.

另外使用 toggleClass() 将是一个很好的方法。

$('.fa.fa-bars').toggleClass(
    'fa-rotate-90', 
    $('.wf-burger').attr('aria-expanded') == 'true'
);
.fa-rotate-90 {
  border:1px solid red;
  height:20px;
  width:20px;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<a aria-expanded="true" aria-controls="drop1" data-dropdown="drop1" href="#" class="wf-burger">
  <i aria-hidden="true" class="fa fa-bars fa-rotate-90"></i>
</a>
<ul aria-hidden="true" class="f-dropdown" id="drop1" data-dropdown-content>
  <li><a title="Link 1" href="#1">Link 1</a>
  </li>
  <li><a title="Link 2" href="#2">Link 2</a>
  </li>
  <li><a title="Link 3" href="#3">Link 3</a>
  </li>
  <li><a title="Link 4" href="#4">Link 4</a>
  </li>
  <li><a title="Link 5" href="#5">Link 5</a>
  </li>
</ul>

一个更简单的解决方案是在点击时简单地切换 class。

$(".wf-burger").click(function(){
   $('.wf-burger .fa').toggleClass('fa-rotate-90');
});

CSS解法

我刚刚检查它在打开下拉菜单时使用打开 class,它不适用于文档,但它正在处理 CodePen 示例,我在其中使用了基础 5.5.3 版本。 http://cdn.foundation5.zurb.com/foundation.js

.wf-burger.open .fa{
  transform: rotate(90deg);
}

参见示例:http://codepen.io/shoaibik/pen/xVevrv

更新答案:

问题是下拉菜单应该是附加到下拉菜单的锚点的兄弟,如果您删除 H1 标签,它应该可以工作。

<a aria-expanded="false" aria-controls="drop1" data-dropdown="drop1" href="#" class="wf-burger">
        <i aria-hidden="true" class="fa fa-bars fa-rotate-90"></i>
</a>
<ul aria-hidden="true" class="f-dropdown" id="drop1" data-dropdown-content>
    <li><a title="Link 1" href="#1">Link 1</a></li>
    <li><a title="Link 2" href="#2">Link 2</a></li>
    <li><a title="Link 3" href="#3">Link 3</a></li>
    <li><a title="Link 4" href="#4">Link 4</a></li>
    <li><a title="Link 5" href="#5">Link 5</a></li>
</ul>