Alb*_*rto 4 jquery events caching object dynamic-rebinding
我正在为Joomla制作一个模块!使用Ajax向数据库呈现不同查询的客户端的页面.这些查询的结果是我重新生成了不同DIV的整个HTML代码.在我的jQuery对象中,我有一个名为的函数,cache()它存储了我需要将不同事件附加到它们的所有对象.我的问题是每次从任何这些div重新生成HTML代码时,我都必须重建所有对象,所以我创建了一个新函数recache()来使这项工作更容易.
我想这不是最好的程序.有没有办法让这些处理程序保持活力,而不必cache()每次都调用此函数,或者有没有办法动态重新绑定这些对象?
谢谢!
这是我的代码:
var Object = {
init: function() {
this.cache();
this.bindEvents();
return this;
},
cache: function() {
OBJECTS....
this.nameObject = $('#anchor');
etc..
},
recache: function() {
Objects to be recached as needed.
},
bindEvents: function() {
EVENTS attached to the objects.
this.nameObject.on( 'click', 'context', this.nameFunction );
},
nameFunction: function() {
#CODE....
}
}; //END Playlist (Object)
window.Object = Object.init();
Run Code Online (Sandbox Code Playgroud)
我通常使用on()函数而不是delegate(),live()或者bind(),但我不确定这是我的问题.
提前致谢!
Gre*_*tit 11
你暗示了正确的计划:使用.on().但请记住,当您委派一个监听器时,您需要委托一个不会被销毁的监听器.
或者换句话说:
// will not do anything useful for this scenario:
$('.something').on('click', function() { /* ... */ });
Run Code Online (Sandbox Code Playgroud)
不同于
// use the document as a listener: will work but not efficient
$(document).on('click', '.something', function() { /* ... */ });
Run Code Online (Sandbox Code Playgroud)
这与...不同
// use a closer ancestor that is NOT destroyed. Best option if you can
$('#someAncestor').on('click', '.something', function() { /* ... */ });
Run Code Online (Sandbox Code Playgroud)