【发布时间】:2012-07-30 21:15:42
【问题描述】:
我正在尝试将填充视图的对象推送到数组中,但引用不知何故丢失了。我有一个 Ember 视图,定义了 eventManager:
FrontLine.NewProductButton = Em.View.extend({
tagName: 'button',
classNames: ['addtl_product',],
templateName: 'product-button',
eventManager: Ember.Object.create({
click: function(event, view) {
FrontLine.ProductsController.toggleProductToCustomer(event, view);
}
})
})
该视图使用#each 帮助器渲染了一组按钮,这些按钮使用来自ProductsController 中的对象的属性进行渲染。那部分效果很好。当我点击这些按钮中的任何一个时,点击事件就会触发并执行我要求的任何操作,包括成功调用我从ProductsController 指定的处理程序函数 (toggleProductToCustomer):
FrontLine.ProductsController = Em.ArrayController.create({
content: [],
newProduct: function(productLiteral) {
this.pushObject(productLiteral);
},
toggleProductToCustomer: function(event, view){
FrontLine.CustomersController.currentCustomer.productSetAdditional.pushObject(view.context);
}
});
我正在尝试使用该函数将其属性填充该视图的对象推送到数组中。我的应用程序中的另一个地方(一个简单的搜索字段),使用pushObject(view.context) 非常好用。然而,在这里,所有被推入数组的是undefined。我尝试改用view.templateContext,但这并没有更好的效果。当我尝试从这些函数中 console.log-ing 按钮的 view 对象时,我得到了我所期望的:
<(subclass of FrontLine.NewProductButton):ember623>
但view.context 或view.templateContext 都返回undefined。如何访问我所追求的对象,以便将其添加到我的数组中?
【问题讨论】:
-
如果你使用 get() 函数而不是直接访问你的属性会发生什么?
-
get() 对于 Ember 来说绝对是必不可少的,但是您将如何在 view.context 上使用它,因为这就是我无法访问的内容?
-
view.get('context') 不起作用?也许我只是不明白
-
不,它没有/没有。见答案。
标签: javascript model-view-controller ember.js dom-events