在javascript中将eventdata传递给事件处理程序

时间:2011-02-02 11:25:48

标签: javascript jquery

我有两个div:

<div id="div1"></div>
<div id="div2"></div>

我对div1有以下jquery:

 $('#div1').click(function(e)
{
alert(e.pageX + ' ' + e.pageY);
});

。 现在,我想触发div1的click eventhandler来执行divc的clcicking。 为此,我写道:

$('div2').click(function(e)
{
$('#div1').trigger('click');
});

它工作正常,但问题是我无法在div1的事件处理程序中获得e.pageX和e.pageY。 如何传递div2 click事件处理程序的eventdata,即div1 click事件处理程序。 请帮忙。

2 个答案:

答案 0 :(得分:6)

由于您要触发的事件属于同一类型,因此您可以直接传递旧事件对象:

$('#div2').click(function (e) {
    $('#div1').trigger(e);
});

对于不同类型的事件,您可以创建自定义事件对象:

$('#div2').mouseenter(function (e) {
    var newE = jQuery.Event('click');
    newE.pageX = e.pageX;
    newE.pageY = e.pageY;
    $('#div1').trigger(newE);
});

答案 1 :(得分:0)

jQuerys .trigger() help 应该是这里的答案。您可以传递事件字符串(以及参数)以及事件对象

$('#div2').click(function(e) {
    $('#div1').trigger(e);
});