Javascript jQuery回调函数传递事件

Javascript jQuery回调函数传递事件,javascript,jquery,Javascript,Jquery,我有一个点击事件,如下所示,效果良好: $('#showmenu').off('click').on('click', function(e) { e.preventDefault(); e.stopPropagation(); show_menu(); return false; }); 显示菜单的位置为: function show_menu(e) { if (!collapseForm.is(':visible')) { colla

我有一个点击事件,如下所示,效果良好:

$('#showmenu').off('click').on('click', function(e) {
    e.preventDefault();
    e.stopPropagation();
    show_menu();
    return false;
});
显示菜单的位置为:

function show_menu(e) {
    if (!collapseForm.is(':visible')) {
        collapseForm.show();
        showMenu.removeClass(chevronDown).addClass(checvronUp);
        searchAgain.hide();
    } else {
        collapseForm.hide();
        showMenu.removeClass(checvronUp).addClass(checvronDown);
        searchAgain.show();
    }
}
我希望能够做到这一点:

$('#showmenu').off('click').on('click', show_menu(e));
是否可以通过执行以下操作将“e”传递给回调函数

function show_menu(e) {
    e.preventDefault();
    e.stopPropagation();
    if (!collapseForm.is(':visible')) {
        collapseForm.show();
        showMenu.removeClass(chevronDown).addClass(checvronUp);
        searchAgain.hide();
    } else {
        collapseForm.hide();
        showMenu.removeClass(checvronUp).addClass(chevronDown);
        searchAgain.show();
    }
    return false;
}

调用函数时(通过事件触发),事件对象被传递给函数

您必须将函数传递给方法上的

$('#showmenu').off('click').on('click', show_menu);

当函数被调用时(通过事件触发),事件对象被传递给函数

您必须将函数传递给
方法上的

$('#showmenu').off('click').on('click', show_menu);

我得到:未捕获引用错误:未定义e,请参阅更新question@Alex-我不明白:看截图attached@Alex-在你写的问题中,
function show_menu(e){e.preventDefault();
。屏幕截图显示的不是这个。我得到:未捕获引用错误:e未定义,请参阅更新question@Alex-我不明白:看截图attached@Alex-在你写的问题中,
function show_menu(e){e.preventDefault();
。屏幕截图显示的不是这个。