触发在不同代码块中分配的jQuery事件处理程序

我遇到的情况是,在一个jQuery代码块(文件)中定义/分配了一个Click处理程序,而我希望从另一个在不同的jQuery代码块中定义/分配的Click事件触发它。我如何才能完成此任务?

下面的代码大大简化了我要实现的目标。当我单击#Element2时,我希望看到的行为是一个JavaScript警告元素。

示例HTML:

<p id="Element1">Element One</p>
<p id="Element2">Element Two</p>

第一个jQuery代码块:

$(document).ready(function() {
    $('#Element1').click(function() {
        alert('Element One');
    });
});

第二个jQuery代码块:

$(document).ready(function() {
    $('#Element2').click(function() {
        $('#Element1').click();
    });
});

更新:我的原始示例实际有效。我是在我的字段提示jQuery UI Dialog solution的基础上构建的,没有考虑到我正在使用的'clickoutside' handler。向我的"clickout"处理程序中的第二个元素添加复选标记允许显示该对话框。


解决方案

您需要在单击第一个元素时触发单击。您可以为此使用trigger方法。

function element1Hanlder () {
    alert('Element One');
}

$(document).ready(function() {
    $('#Element1').click(function() {
        alert('Element One');
    });
});

$(document).ready(function() {
    $('#Element2').click(function() {
        $('#Element1').trigger('click');
    });
});

相关文章