我正在使用Backbone.js为每个模型的视图都有一个分段控件类型的UI元素。它们各自由具有少量li元素的ul组成。我想绑定一个事件,以便在单击其中一个元素时,我可以确定单击了哪个元素并使用适当的值更新模型。
问题是Backbone绑定事件(这些是在视图的事件哈希中),这样回调函数中的“this”指的是视图,而不是li元素。这意味着我无法确定单击了哪些li元素。如果我使用普通的jQuery绑定,我可以将“this”绑定到li元素,但是我不再跟踪模型了,所以我无法更新它。
答案 0 :(得分:44)
jQuery将this
设置为当时非常方便的习惯是一种非常讨厌的模式,在我看来 - 幸运的是,你永远不必依赖它:
onClick: function(e) {
this; // Still the view instance (as it should be).
e.target; // The element that was clicked.
e.currentTarget; // The element that was bound by the click event.
}
...您可以根据需要使用事件对象的target
或currentTarget
。
答案 1 :(得分:20)
无法弄清楚为什么我不能评论@jashkenas上面的回答。他的方法是正确的(谢谢!)但我想我会澄清这种情况:在你的事件处理程序中,你可以恢复事件绑定的元素。示例骨干代码如下所示:
MyView = Backbone.View.extend({
events: {
'click .item': 'handleClick'
},
handleClick: function(e) {
this; // The view instance
e.target; // The element that was clicked
e.currentTarget; // The element that was bound by the click event
}
});
我用它在我的所有表单字段中设置默认文本...是的我还没有进入HTML5:)
修改强> 顺便说一下,e.target是原始元素。您需要使用$(e.target)来获取jQuery。