我认为这个问题最终归结为我应该在哪里放置 JQuery 代码,我不确定backbone.js。
我有一个嵌套的 div :
<div>Parent
<div class='pull-right remove-measure-btn'>Child</div>
</div>
我希望孩子只在父母悬停时显示。
render()
所以我可以使用这段代码(父Backbone.View.extend中的func()中的顶行:
render: function():
....
$(this.el).hover(
function() {
$('.remove-measure-btn').show();
// $('.remove-measure-btn').css('visibility' : 'visible');
},
function() {
$('.remove-measure-btn').hide();
// $('.remove-measure-btn').css('visibility' : 'hidden');
}
);
....
return this;
},
但这只会切换显示,并且由于我正在使用 Bootstrap 并利用.pull-right
,我需要切换 CSS' :visibility
,而不是display:
在不可见时保持子 div 的高度。因此,如果我使用上述代码块中的第二行,我会收到一个未定义的错误,因为已返回已编译的模板(我认为....)。
那么我应该在哪里放置 JQuery 来更改 CSS 可见性,或者如何更改渲染以适应代码所在的位置?
笔记:
- 有许多这样的“父”和“子”div。
- 我假设最好使用选择器
this.el
来直接绑定交互,而不是使用多个全局document.ready()
s,但也许我不知道使用这种方法完成它的“安全/良好”方式