4

我在 div 上有一个点击侦听器,在 div 内部我有一个带有普通标签的链接,但是每当我点击该链接时,事件也会运行。如果单击 div 内的链接,如何防止单击侦听器中的内容运行?

HTML:

<div class="container item-container" data="skarp-version-av-os-x-10.8.3-slappt">
        <div class="item">
            <div class="number">
                <p class="number-data">1</p>
            </div>
            <div class="upvotes btn tooltip-points" points="4" id="90" data-toggle="tooltip" title="" data-original-title="Visar poäng satta de senaste 24 h">
                4 poäng
            </div>
            <div class="item-content">
                <a href="http://feeds.idg.se/~r/idg/ETkj/~3/XSuYKgEiumE/skarp-version-av-os-x-1083-slappt" target="_blank" class="item-link fill-div">Skarp version av OS X 10.8.3 släppt</a>
                <span class="item-source">(feeds.idg.se)</span>
                <p class="item-author">Upplagd av Anonym - <em>2013-03-17 21:07:08</em></p>
            </div>
            <div class="comment">
                <i class="icon-comment"></i> <a href="http://www.tldr.nu/item/view/skarp-version-av-os-x-10.8.3-slappt#disqus_thread">0 Comments and 0 Reactions</a>
            </div>
        </div>
    </div>

Javascript:

$('.item-container').click(function(event) {
    var url = $(this).attr('data') ? $(this).attr('data') : '';
    if(url != '')
        window.location = getBaseURL() + 'item/view/' + url;
});
4

5 回答 5

2

您可以在链接上添加一个事件处理程序以阻止单击事件冒泡到 div,或者您可以在 div 的处理程序内添加一个 if 语句,以便在事件目标是链接时忽略单击事件。我认为前一种解决方案将是可行的方法。

这会在链接上设置一个事件处理程序,以阻止单击事件传播到 div:

$('.item-container a').click(function(event) {
   event.stopPropagation();
});

jsfiddle 演示

于 2013-03-17T22:17:24.520 回答
1

您要么需要将特定的预防方法绑定到内部元素,就像这样 -

$("a").click(function(e){
    e.stopPropagation();
});

或者你需要嗅探被点击元素的类型——

$(".wrap").click(function(e){
    if ($(e.target).hasClass("wrap")){
       alert("click");
    }
});

第二种方法通常更可取,因为要出现这个问题,你的内在元素有它们自己的事件,你希望它们能够正常运行。

但是,也许您希望链接在单击时不触发父 div 效果,在这种情况下,第一个效果更好。

小提琴 - http://jsfiddle.net/WXzjP/

于 2013-03-17T22:20:04.783 回答
0

熟悉事件冒泡- 您需要了解基础知识才能最终了解事件委托

您可以通过以下两种方式之一解决您的问题。将 click 事件绑定到<a>您的<div>and callevent.stopPropagation();中,或者让<div>的事件处理程序检查event.target是否是一个<a>元素:

if (event.target.nodeName.toLowerCase() === 'a') {
  // <a> was clicked
}
于 2013-03-17T22:21:38.420 回答
0

因为它“冒泡了”。可以这样想;

当你点击你的链接时,它有一个你指定的动作:导航到一个 url。接下来,它“冒泡”树,你还有一个 div 的点击处理程序,所以它会尝试运行它也。

如果您也有一个点击处理程序,$('body')也将被调用。

你必须停止冒泡event.stopPropagation();

例如

$('#your-anchor-tag').click(function(e) {
 e.stopPropagation();
}

这样,您将停止冒泡过程..

于 2013-03-17T22:23:30.077 回答
0
$('.item-container').click(function(event) {
    if(!$(event.target).is('a')) {
        var url = $(this).attr('data') ? $(this).attr('data') : '';
        if(url != '')
            window.location = getBaseURL() + 'item/view/' + url;
    }
});

检查启动事件的事件目标是否是锚元素,如果不是,则执行您的函数。

于 2013-03-17T22:19:44.810 回答