ember.js - 将文本字段绑定(bind)到 ember 中的模型的最佳方法

标签 ember.js ember-data

我试图弄清楚如何将模型绑定(bind)到文本字段,以便在更新文本字段中的值时,也更新底层模型(并将 PUT 请求发送到适当的 API)。从文档 ember-data 似乎能够做到这一点,但我无法将我的自定义文本字段连接到 Controller /模型。

这是我的模型的外观:

AS.Run = DS.Model.extend({
'analyticsPlan' : DS.attr('string'),
'commandScript' : DS.attr('string'),
'parameters'    : DS.hasMany('parameter')
});

AS.Parameter = DS.Model.extend({
'name'          : DS.attr('string'),
'type'          : DS.attr('string'),
'description'   : DS.attr('string'),
'value'         : DS.attr('string'),
'default'       : DS.attr('string'),
'analyticRun'   : DS.belongsTo("run")
});

这是我的模板:
<table style="width:100%;" class="affi-table">
        <thead>
            <tr class="ui-state-default">
                <th style="width:120px;">Parameter Type</th>
                <th style="width:120px;">Parameter Name</th>
                <th>Description</th>
                <th>Default value</th>
                <th>Value</th>
            </tr>
        </thead>
        <tbody>
              {{#each parameter in parameters}}
                <tr>
                    <td>{{parameter.type}}</td>
                    <td>{{parameter.name}}</td>
                    <td>{{parameter.description}}</td>
                    <td>{{parameter.default}}</td>
                    <td>{{view AS.AnalyticsParameterTextField valueBinding="parameter.value" placeholder="" nameBinding="parameter.name" style="width:200px;"}}</td>
                </tr>
              {{/each}}
        </tbody>
    </table>

AnalyticsParameterTextField 定义为:
AS.AnalyticsParameterTextField = Ember.TextField.extend({
attributeBindings: ['name','style'],

focusOut: function(evt) {
    var paramName = this.get('name');
    var paramValue = this.value;

    console.log(this.get('controller'));//this returns <AS.AnalyticsParameterTextField:ember568> which is not the controller
    //this was working before when I was not using ember model objects, but when I was just pulling the json data right out from a rest end point

}
});

我真的可以使用一些帮助来弄清楚如何在 AnalyticsParameterTextField 中获取 Controller 。一旦解决了这个问题,我需要弄清楚如何更新底层模型并发出服务器 API 请求来更新数据库。我想我可以发出 ajax 请求来更新底层数据库,但在 ember-data 版本 1 中,我想我可能可以在我的 Controller 中使用类似这样的东西:
var p = this.get('store').find('parameter',somekey)  
p.save();

更新:

我现在可以使用 Ember TextField valueBinding with dynamic property 中提供的示例来完成工作。
但似乎必须有更好的方法来解决这个问题。

我的模板看起来像:
{{#each parameter in parameters}}
  <tr>
    <td>{{parameter.type}}</td>
    <td>{{parameter.name}}</td>
    <td>{{parameter.description}}</td>
    <td>{{parameter.default}}</td>
    <td>{{view AS.AnalyticsParameterTextField paramValueBinding="parameterValue" valueBinding="parameter.value" placeholder="" nameBinding="parameter.name" style="width:200px;"}}</td>
</tr>
{{/each}}

文本字段代码如下所示:
AS.AnalyticsParameterTextField = Ember.TextField.extend({
attributeBindings: ['name','style'],
paramValue : {},
updateValues: function() {
    var name = this.get('name');
    var val = this.value;
    this.set('paramValue',{"name":name,"value":val});
}.observes('value')
});

我的 Controller 看起来像:
AS.AnalyticsConfigController = Ember.ObjectController.extend({

runId : null,
parameterValue : null,

/*
* This function is called every time a parameter is updated/changed.
* It makes API call to appropriate rest end point("/analytics/runs/:runId/parameters/:name" to be specific)
*/
updateRunParameter:function(){
    var store = this.get('store');
    var runId = this.get('runId');

    /*
    * defining namespace rule for the "parameter" model here because the namespace depends on the dynamic parameter value "runId"
    */
    AS.ParameterAdapter = DS.RESTAdapter.extend({
        namespace: AS.baseURL.substr(1)+"analytics/runs/"+runId
    });

    store.find('parameter', 'historyDir').then(function(parameterObject) {
        //once the promise is resolved, save the parameter object
        parameterObject.save();
    });
}.observes('parameterValue')
});

但我必须说我讨厌这种方法,必须有一种更清洁的方法来做到这一点。现在,当文本字段值更新时,它会更新自己的属性,进而更新 Controller 属性,然后 Controller 会监视此属性以进行适当的 API 调用。

最佳答案

根据指南的入门部分所说,您应该使用 {{input}} 帮助器而不是自定义 View http://emberjs.com/guides/getting-started/marking-a-model-as-complete-incomplete/ )。它应该如下所示:

<td>{{input type="text" value=parameter.value}}</td>

Controller 知道哪条记录在哪里,这就是为什么它可以“神奇地”在输入 HTML 元素与其对应记录的值之间建立链接。

现在对于 focusOut 部分,我将使用 td 上的 {{action}} 助手来捕获事件(请阅读此事件类型:http://emberjs.com/guides/templates/actions/#toc_specifying-the-type-of-event),如下所示:
<td {{action "focusOut" parameter on="focusOut">{{input type="text" value=parameter.value}}</td>

“focusOut” Action 必须在您的 Controller 中设置,参数是您发送给函数的模型,on="focusOut"是 Action 响应的事件。
将参数发送到 Action “focusOut”的好处是,在 Controller 的 focusOut Action 中,您可以简单地调用:
---- controller code ----

focusOut: function(model){
 model.save();
}

---- controller code ----

也就是说,如果您使用的是 Ember-Data,商店会知道您的模型和要使用的适配器,因此您只需调用 save(它位于 DS.Model 类下的 Ember-Data API 中)。

由于我现在只使用 FIXTURES,所以我不能真正谈论适配器,但您可以查看指南的模型部分,它可能会对您有所帮助。

关于ember.js - 将文本字段绑定(bind)到 ember 中的模型的最佳方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18724822/

相关文章:

javascript - 如何将 emberjs 中的项目列表中的特定项目信息链接到模板

javascript - EmberJS - 一种查询参数绑定(bind)到输入字段值的方法被破坏

javascript - Ember 合并路由数据

ember.js - 从其他 Controller 访问 Controller

ember.js - 与mixin的多态关系

ember.js - Ember数据: model. get ('modelName')是未定义的,但是model._internalModel有效

javascript - Ember 。 DS.Adapter 的自定义 createRecord 不会被触发

ember.js - 如何链接到 Ember.js 中的嵌套资源?

javascript - EmberJS 属性在创建记录时不会自动更新

ember.js - 恢复对 ember 数据模型的更改