使用 jQuery 重新绑定 DOM 事件

2024-04-11

这纯粹是一个理论问题,所以我不是在寻找替代解决方案。

有没有办法让默认处理程序执行类似的操作

var defaultHandler = $("#test").click;
$('#test').unbind('click');
$('#test').bind('click', defaultHandler);

您可以访问.data('events')对象,用于存储所有事件处理程序信息:

$(document).ready(function() {
    var $test = $('#test');

    $test.bind('click', function() {
        alert('default handler');
    });   

    var storedClick = $test.data('events').click[0].handler;

    $test.unbind('click');

    $('#restore').click(function() {
        $test.bind('click', storedClick);
    });
});

看看实际效果:http://www.jsfiddle.net/76GPF/ http://www.jsfiddle.net/76GPF/

请记住,events object持有Arrays,所以在现实世界中你应该存储完整的数组信息。我刚刚在这个例子中存储了第一个处理程序。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

使用 jQuery 重新绑定 DOM 事件 的相关文章

随机推荐