我正在尝试创建一个 jQuery 特殊事件,该事件在绑定的内容发生更改时触发。我的方法是用 a 检查内容setInterval
并检查内容是否与上次相比发生了变化。如果你有更好的方法,请告诉我。另一个问题是我似乎无法清除间隔。无论如何,我需要的是使用event.special
.
(function(){
var interval;
jQuery.event.special.contentchange = {
setup: function(data, namespaces) {
var $this = $(this);
var $originalContent = $this.text();
interval = setInterval(function(){
if($originalContent != $this.text()) {
console.log('content changed');
$originalContent = $this.text();
jQuery.event.special.contentchange.handler();
}
},500);
},
teardown: function(namespaces){
clearInterval(interval);
},
handler: function(namespaces) {
jQuery.event.handle.apply(this, arguments)
}
};
})();
并像这样绑定它:
$('#container').bind('contentchange', function() {
console.log('contentchange triggered');
});
我得到了console.log
“内容更改”,但没有得到“内容更改console.log
触发”。所以很明显,回调永远不会被触发。
我只是使用 Firebug 来更改内容并触发事件,进行测试。
更新
我认为我说得不够清楚,我的代码实际上不起作用。我正在寻找我做错了什么。
这是任何有兴趣的人的完成代码
(function(){
var interval;
jQuery.event.special.contentchange = {
setup: function(){
var self = this,
$this = $(this),
$originalContent = $this.text();
interval = setInterval(function(){
if($originalContent != $this.text()) {
$originalContent = $this.text();
jQuery.event.handle.call(self, {type:'contentchange'});
}
},100);
},
teardown: function(){
clearInterval(interval);
}
};
})();
感谢 Mushex 帮助我。