站点组件之一为此加载脚本。
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>
但是无论如何,都会触发第一个代码中定义的事件。如何覆盖事件并运行不同的代码?
所以这是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的数组。