MooTools中分配的jQuery中的Override事件

问题描述 投票:-1回答:1

站点组件之一为此加载脚本。

window.addEvent('domready', function(){ 
    $$('.kqreply').each(function(el){
        el.addEvent('click', function(e){
            e.stop();
            // SOMETHING ELSE.
    });
});

它已加载到外部JS文件中。之后,我将声明加载到头部。

<script>
    jQuery(document).ready(function(){
        $$('.kqreply').each(function(el){
            el.removeEvent('click');
        });

        jQuery('.kqreply').unbind('click');

        jQuery('.kqreply').each(function(){
            jQuery(this).click(function(e){
                e.preventDefault();
                e.stopPropagation();
            });
        });
    });
</script>

但是无论如何,都会触发第一个代码中定义的事件。如何覆盖事件并运行不同的代码?

jquery mootools mootools-events
1个回答
0
投票

所以这是api:https://github.com/mootools/mootools-core/blob/master/Source/Element/Element.Event.js#L83-L101

mootools允许您删除不属于您的事件,这不是一个伟大的设计决定,目前已更改为主要事件-但在这里很适合您。

使用任一

$$('.kqreply').removeEvents('click'); 
// or all mootools events...
$$('.kqreply').removeEvents();`

您可以通过元素存储访问不属于您的单个功能。

el.retrieve('events')['keys']['click']将是所有绑定到click事件的fn的数组。

© www.soinside.com 2019 - 2024. All rights reserved.