[英]How to hide UL only when clicked outside of to DOCUMENT?
我不确定为什么会出错,并且每次尝试比较目标时,我都不确定。
我在这里做错了什么?
menu.find('> li').each(function() {
var li = $(this);
var ul = li.find('> ul');
var a = li.find('> a');
if(ul.length) {
a.click(function(event) {
event.preventDefault();
event.stopPropagation();
if(a.hasClass('open')) {
a.removeClass('open');
}
else {
a.addClass('open');
}
ul.toggle();
$(document).click(function() {
var target = $(event.target);
alert(target.attr('class'));
if(!target.is(ul) && !target.is(li) && !target.is(a)) {
ul.hide();
}
});
});
}
});
我在您的代码中发现了几个错误:
$(document).click()
事件移到每个循环之外。 否则,此事件将根据页面上有多少menu>li
附加多次。 alert(target.attr('class'));
undefined
的原因alert(target.attr('class'));
这是因为您没有为点击事件提供参数。 将您的代码更改为: $(document).click(function (event) {});
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.