当 #link 绑定了其他的 js 事件时,又该如何做呢?

比如下面这种:

HTML:

<div class="hello">
<a href="http://example.com" target="_blank" id="link">link</a>
<p>say hello world to everynone</P>
</div>

jQuery:

$('.hello').click(function() {
    $('p').toggleClass('hidden');
});

1. 当点击 .hello 任何区域都能将 p 隐藏,但我不希望点击 #link 的时候 p 也隐藏,应该如何做呢?


LEATH
浏览 77回答 2
2回答

慕盖茨4494581

$('.hello').click(function(e){&nbsp;&nbsp;if(e.target.tagName&nbsp;!=&nbsp;'A'&nbsp;){ &nbsp;&nbsp;&nbsp;&nbsp;$('p').toggleClass('hidden'); &nbsp;&nbsp;}&nbsp; });判断一下点击事件的目标节点即可,当 #link 绑定了其他的 js 事件时这样处理也没问题。

墨色风雨

可以用JQuery的stopPropagation()方法来阻止事件冒泡。link点击的时候处理一下:$('#link').click(function(e){ &nbsp;&nbsp;&nbsp;&nbsp;e.stopPropagation(); });
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

JavaScript