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();
。屏幕截图显示的不是这个。