首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在所选元素上添加类并从其他元素中删除?

如何在所选元素上添加类并从其他元素中删除?
EN

Stack Overflow用户
提问于 2018-11-08 20:43:49
回答 2查看 82关注 0票数 0

这是我的HTML:

代码语言:javascript
复制
<ul class="menu menu-primary">
    <li class="current has-children">
        <a href="">Home</a>
        <span class="menu-item-toggle">
            <span></span>
        </span>
        <ul class="sub-menu">
            <li class="current-children"><a href="" class="">Homepage-1</a></li>
            <li class=""><a href="" class="">Home-2</a></li>
            <li class=""><a href="" class="">Home-3</a></li>
        </ul>
    </li>
</ul>

现在我想要的是,点击“菜单项-切换”,“菜单-展开”被添加到各自的“li.has- click”中,并从其他li中删除。

下面是我的脚本:

代码语言:javascript
复制
$('ul.menu li.has-children').each(function () {
    var menuItem = $(this)
    var menuToggle = $('<span class="menu-item-toggle"><span></span></span>')

    menuToggle.insertAfter(menuItem.find('> a')).on('click', function () {
        menuItem.toggleClass('menu-expand');
        menuItem.nextAll().removeClass('menu-expand');
        menuItem.prevAll().removeClass('menu-expand');
    })
})
EN

回答 2

Stack Overflow用户

发布于 2018-11-08 20:54:25

尝尝这个

代码语言:javascript
复制
$('ul.menu li.has-children').click(function () {
    $('ul.menu li.has-children').each(function () {
        $(this).removeClass('menu-expand');
    });
    $(this).addClass('menu-expand');
});
票数 0
EN

Stack Overflow用户

发布于 2018-11-08 20:56:20

您可以通过以下方式完成此操作。

代码语言:javascript
复制
 $('ul.menu li.has-children').each(function () {
        var menuItem = $(this)
        var menuToggle = $('<span class="menu-item-toggle"><span></span></span>')
        $(this).removeClass('menu-expand');
        menuToggle.insertAfter(menuItem.find('> a')).on('click', function () {
            menuItem.toggleClass('menu-expand');
            menuItem.nextAll().removeClass('menu-expand');
            menuItem.prevAll().removeClass('menu-expand');
            $(this).addClass('menu-expand');
        })
    })
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53208000

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档