3

我有以下代码它需要 a<ul>并在单击时下拉内容。这很好用。问题是当单击 a 时它也会关闭相同类型的其他菜单child <li>

我通过使用该if子句确定被单击的项目是否也是当前打开的项目来“修复”这个问题,但我想更进一步并使其如果再次单击 项,它将关闭菜单。我对如何解决这个问题有很多误解。我试图阻止子元素的传播,但它产生了相同的结果。有人可以帮忙吗?ul

接线(文件加载)

$(document).ready(function () {
                $('[data-role="sidebar-dropdown"]').drawer({
                    open: 'sidebar-dropdown-open',
                    css: '.sidebar-dropdown-open'
                });
        });

html

<ul>
    <li class=" dropdown" data-role="sidebar-dropdown">
        <a href="pages/.." class="remote">Link Text</a>
        <ul class="sub-menu light sidebar-dropdown-menu">
            <li><a class="remote" href="pages/...">Link Text</a></li>
            <li><a class="remote" href="pages/...">Link Text</a></li>
            <li><a class="remote" href="pages/...">Link Text</a></li>
        </ul>
    </li>
</ul>

javascript

(function ($) {
    $.fn.drawer = function (options) {
        // Create some defaults, extending them with any options that were provided
        var settings = $.extend({
            open: 'open',
            css: '.open'
        }, options);

        return this.each(function () {
            $(this).on('click', function (e) {
                // slide up all open dropdown menus
                $(settings.css).not($(this)).each(function () {
                    $(this).removeClass(settings.open);
                    // retrieve the appropriate menu item
                    var $menu = $(this).children(".dropdown-menu, .sidebar-dropdown-menu");
                    // slide down the one clicked on.
                    $menu.slideUp('fast');
                    $menu.removeClass('active');
                });


                // mark this menu as open
                $(this).addClass(settings.open);

                // retrieve the appropriate menu item
                var $menu = $(this).children(".dropdown-menu, .sidebar-dropdown-menu");
                // slide down the one clicked on.
                $menu.slideDown(100);
                $menu.addClass('active');
                e.preventDefault();
                e.stopPropagation();

            }).on("mouseleave", function () {
                $(this).children(".dropdown-menu").hide().delay(300);
            });

        })
    };

})(jQuery);
4

1 回答 1

2

在 jQuery 事件中,您可以通过引用来读取启动事件的节点e.target

if ($(e.target).is("li")) { // do something only if the clicked element was a li }

关于关闭不是子元素的元素,而不是做一个全局选择器$(selector),你应该做一个相对于你的初始 dom 节点的选择器。this在 jQuery 插件中传递和存储它是一种常见的做法。

return this.each(function(this)) { var $node = $(this); }

然后所有的查找都会像

$node.find(selector).doStuff()

于 2012-12-05T20:57:04.103 回答