我在template.onDestoyed中遇到了错误和奇怪的行为;
我有无限滚动订阅的代码(它存储在特殊的订阅模板中)它工作正常,直到我切换到另一个路由,并创建一个新的subscriber-template实例。
代码:
Template.subscriber.onCreated(function() {
var template = this;
var skipCount = 0;
template.autorun(function(c) {
template.subscribe(template.data.name, skipCount, template.data.user);
var block = true;
$(window).scroll(function() {
if (($(window).scrollTop() + $(window).height()) >= ($(document).height()) && block) {
block = false;
skipCount = skipCount + template.data.count;
console.log(template.data);
console.log("skip_count is "+skipCount);
template.subscribe(template.data.name, skipCount, template.data.user, {
onReady: function() {
block = true;
},
onStop: function() {
console.log('route switched, subscribtion stopped');
}
});
}
});
})
});
当我"向下滚动"在页面上,订阅者工作正常,当我进入另一页并且"向下滚动"首先,我从第一次获得旧订户模板(理论上必须销毁的)数据。在第二次(再次向下滚动)新订户启动实例正常工作。
我做错了什么?
答案 0 :(得分:0)
Owch!
来自流星论坛的好人帮助了我。
实际上问题出在jquery.scroll
事件中。模板被销毁时不会清理它。 (这是一个错误吗?或者这是正常的行为?)。我只需解开onDestroyed
部分中的滚动事件。