不再需要视图后取消委派事件的最佳方法
The best way to undelegate events once a view is no longer needed
视图remove()
方法中调用undelegateEvents()
是一种不好的做法吗?为什么骨干人员没有默认包含它?
意识到在简单地重新初始化视图变量时,我遇到了很多绑定问题。尽管创建新视图时会自动调用undelegateEvents()
,但它会尝试取消委派新实例化视图的事件,而不是前一个视图。因此,除非每次都手动调用它,否则 ghost 事件回调将保持活动状态并搞砸我的应用程序。
处理这个问题的最佳方法是什么?
在视图
remove()
方法中调用undelegateEvents()
是一种不好的做法吗?
除非您正在实现自己的remove()
并且不调用Backbone.View.remove()
或this.$el.remove()
,否则没有必要。 至少如果你使用的是jQuery。 在主干视图上调用remove()
将调用jQuery.remove()
这将删除所有 DOM 事件侦听器。
我意识到在简单地重新初始化视图变量时,我遇到了很多绑定问题。
很多人似乎都在使用Backbone.Events,就像它是某种不需要清理的魔法,例如:
var View = Backbone.View.extend( {
initialize : function ( options ) {
// `on()` or `bind()`
this.model.on( 'something', this.render, this );
}
} );
请参阅我在 Backbone 中将事件委派给父视图的答案
您遇到的幻影事件问题是否可能与主干事件而不是 DOM 事件有关?
如果保留模型对象,但想要删除该视图对象或其主干事件注册,则必须执行view.model.off( null, null, this );
。 您必须取消绑定已注册到任何外部对象的事件。 如果需要,您可以覆盖Backbone.View.remove()
并在那里执行此操作,但默认情况下,该方法只是 view.$el.remove()
的简写。
- 什么'是在HTML5画布中创建关键事件的最佳方式
- 在Nodejs中堆叠异步回调事件的最佳方式
- addEvent()传奇事件之后的当前最佳实践是什么
- 主干.js事件处理程序命名的最佳做法
- 在 Web 应用中处理事件跟踪的最佳(高性能)方法
- 将 react-redux 与基于事件的第三方库一起使用的最佳方法是什么?
- 用于查找基于时间的事件的最佳Javascript算法
- 通知全局事件组件的最佳方式
- 处理多次单击事件的最佳方式
- 在大型系统中附加事件处理程序的最佳做法
- 为输入字段(而不是表单的一部分)设置默认按钮(或在 javascript 中触发其事件)的最佳方法
- 当文档中的单个元素准备就绪时触发事件的最佳方法
- Javascript:注册事件处理程序的最佳位置
- 不再需要视图后取消委派事件的最佳方法
- React,在组件事件上呈现消息的最佳方法
- 这真的是从事件回调中获取 Rx.Observable 的最佳方式吗?
- 使用jsduck记录事件处理程序的最佳方式是什么
- 什么'是在AngularJS中处理应用程序状态和事件广播的最佳实践
- 从中停用单击事件的最佳方式是什么
- 跟踪javascript中文本框控件上触发的退格事件位置的最佳方法