2

如果我在其中单击,为什么这段代码会隐藏在 blur() 上用作 jQuery 选择器的 div?Blur() 只有在我点击它外部时才应该隐藏它。

HTML 触发器:

<div class="header">To-Do <a class="triggernewtodo">Add a task...</a></div>

li 显示/隐藏:

<li class="addnewtodo">
<form>
    <textarea class="addtodotextarea"></textarea>
    <div class="controlarea">
    <input class="primary" name="commit" type="submit" value="Add" />
    </div>
</form>
</li>

jQuery:

// Show/Hide New Todo form
$('a.triggernewtodo').click(function() {
    $('li.addnewtodo').show()
    $('textarea.addtodotextarea').focus();
});

$('li.addnewtodo').live("blur", function() {
    $(this).hide();
})

我的猜测是它与放置在 textarea 上的 .focus() 有关,因为如果我取出那个 .focus(),它会正常工作,直到我在 textarea 内单击然后单击 out(仍在列表项内)它隐藏了整个列表项。有任何想法吗?我究竟做错了什么?

4

1 回答 1

1

我怀疑您正在看到从该 LI 中“冒泡”的事件。本质上,来自 INPUT 的“模糊”事件会触发该输入上的所有“模糊”处理程序。 然后它触发 FORM 上的所有“模糊”处理程序。然后它触发 LI 上的“模糊”处理程序 - 隐藏它。

除非您调用stopPropagation来阻止这种情况,否则该事件会一直沿 DOM 树向上继续。在您的情况下,您应该能够使用event.target属性来查看事件是否实际上起源于 LI,并且仅在这种情况下将其隐藏(警告:未经测试):

$('li.addnewtodo').live("blur", function(event) {
    if(event.target == this)
    {
        $(this).hide();
    }
});

希望有帮助!

PS:有关其他警告,请参阅模糊事件页面。

于 2012-12-05T20:55:28.503 回答