如何忽略第一个事件并跳到第二个?

Tre*_*vor 3 javascript javascript-events

我有一个表行,在表格行的任何地方都有鼠标点击附加的Javascript操作:

<tr onmousedown="someAction(this)">
    <td>cell 1</td>
    <td>cell 2</td>
    <td><a href="page2.html">cell 3</a></td>
</tr>
Run Code Online (Sandbox Code Playgroud)

如果用户点击该行中的任何位置,我希望遵循Javascript操作someAction(this).但是,如果用户单击指向page2的链接,那么我希望忽略该操作并遵循链接.

不幸的是,首先会观察到该动作,这恰好会使链接文本的位置移动到足以使点击被删除.换句话说,在这种情况下,用户实际上无法点击链接并转到第2页.

如何禁用链接点击的mousedown操作?

谢谢!

更新: 基于答案,我最终在HTML的末尾包含了以下JavaScript,它按照建议注册了一个停止传播的事件处理程序,如下所示:

...
<script type="text/javascript" language="javascript">
//<![CDATA[
function stopEvent(ev) {
    ev.stopPropagation();
}
var links = document.getElementsByTagName('a');
for (var i = 0; i < links.length; i++) {
    links[i].addEventListener("onmousedown", stopEvent, false);
}
//]]>
</html>
Run Code Online (Sandbox Code Playgroud)

这可能很容易被包含在文档的onload事件中,但CDATA部分已经因其他原因而被要求,所以我在这里添加了我需要的内容.

感谢所有的帮助和好建议!:)

unc*_*ton 5

如果你使用的是jQuery,那就简单了(假设你为tr元素设置了id ='row',为元素设置了id ='link'):

$('#row').click(someaction);
$('#link').click(function(event){event.stopPropagation()});
Run Code Online (Sandbox Code Playgroud)

你可以看一下这个例子:http://jsfiddle.net/VDQMm/

没有jQuery,它几乎是相同的,但你必须先获取每个元素的句柄,然后使用addEventListener方法附加一个事件监听器(使行处理程序使用冒泡而不是通过将最后一个参数设置为false来捕获),然后同样的旧event.stopPropagation().

它会是这样的(http://jsfiddle.net/VDQMm/2):

var row = document.getElementById('row');
var link = document.getElementById('link');
row.addEventListener('click',alert('clicked row!'),false)
link.addEventListener('click',function(event){event.stopPropagation()},false)
Run Code Online (Sandbox Code Playgroud)