- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有两个表单元素,都是通过backbone.stickit 进行双向数据绑定(bind)的。第二个表单元素(#input)只是装饰性的 - 用于显示它实际上正在工作。
这个想法是,每次下拉(#select)菜单中的选项发生更改时,我的 View 都会(重新)渲染。
我试图通过捕获 #select 的“changed”事件并调用 this.render() 来(重新)渲染 View 来实现这一目标。
显然这不起作用。所选选项不会保存回模型中,我不明白为什么。
我不是在寻找解决方案,而不是解释,为什么以下代码不起作用。解决方案(如:对我有用)是 fiddle 的一部分 - 已注释掉。
HTML:
<script type="text/template" id="tpl">
<h1>Hello <%= select %></h1>
<select id="select">
</select>
<p>Select:
<%= select %>
</p>
<hr>
<input type="text" id="input">
<p>Input:
<%= input %>
</p>
</script>
<div id="ctr"></div>
JavaScript:
Foo = Backbone.Model.extend({
defaults: {
select: "",
input: "",
}
});
FooView = Backbone.View.extend({
el: '#ctr',
template: _.template($('#tpl').html()),
initialize() {
this.model.bind('change', function() {
console.log("model change:");
console.log(this.model.get('select'));
console.log(this.model.get('input'));
}, this);
//this.model.bind('change:select', function() { this.render(); }, this); // <--------------------- WORKS
},
render: function() {
this.$el.html(this.template(this.model.toJSON()));
this.stickit();
return this;
},
events: {
'change #select': function(ev) {
console.log('change event triggered:');
console.log(this.model.get('select'));
console.log(this.model.get('input'));
this.render(); // <--------------------- DOES NOT WORK - WHY?
},
/* 'click #render': function(ev) {
console.log('render event triggered:');
console.log(this.model.get('select'));
console.log(this.model.get('input'));
this.render();
} */
},
bindings: {
'#input': 'input',
'#select': {
observe: 'select',
selectOptions: {
collection: function() {
return [{
value: '1',
label: 'Foo'
}, {
value: '2',
label: 'Bar'
}, {
value: '3',
label: 'Blub'
}]
}
}
},
},
});
new FooView({
model: new Foo()
}).render();
最佳答案
从 change #select
事件处理程序中调用 this.render()
不起作用的原因是您破坏了双向数据绑定(bind), Backbone.stickit正在为您提供。流程如下:
change #select
处理程序将触发并调用 this.render()
。render
使用新的选择菜单重新填充 #ctr
,但未选择任何选项
。#select
的更改。#select
的值,但由于它不包含选定的选项
,因此该值为未定义
。<模型
的select
属性设置为未定义
。如果将 this.render()
调用移至 model
的 change:select
处理程序中,它会起作用的原因是Backbone.stickit 能够正确更新模型,而无需在有机会之前更改 DOM。
关于javascript - 在更改事件处理程序中(重新)渲染 Backbone View 不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36380398/
今天有小伙伴给我留言问到,try{...}catch(){...}是什么意思?它用来干什么? 简单的说 他们是用来捕获异常的 下面我们通过一个例子来详细讲解下
我正在努力提高网站的可访问性,但我不知道如何在页脚中标记社交媒体链接列表。这些链接指向我在 facecook、twitter 等上的帐户。我不想用 role="navigation" 标记这些链接,因
说现在是 6 点,我有一个 Timer 并在 10 点安排了一个 TimerTask。之后,System DateTime 被其他服务(例如 ntp)调整为 9 点钟。我仍然希望我的 TimerTas
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我就废话不多说了,大家还是直接看代码吧~ ? 1
Maven系列1 1.什么是Maven? Maven是一个项目管理工具,它包含了一个对象模型。一组标准集合,一个依赖管理系统。和用来运行定义在生命周期阶段中插件目标和逻辑。 核心功能 Mav
我是一名优秀的程序员,十分优秀!