如何使用淘汰映射插件?

时间:2014-01-09 09:48:43

标签: knockout.js knockout-mapping-plugin

我想使用插件来填充数据,但不会填充值。

简单示例:

var data = {
    Type: 1,
    Id: "123-12321"
};

var RiskItemModel = function (item) {
    var self = this;
    self.Id = ko.observable("tes");
    self.Type = ko.observable(); //enum int


    if (item) {
      // DATA SHOULD BE POPULATED HERE, but no effect
      ko.mapping.fromJS(item, this);
    };
};

var model = new RiskItemModel(data);
ko.applyBindings(model);

// I HAVE TRIED THIS ALSO, NO EFFECT
//ko.mapping.fromJS(data, model);

HTML:

<div>
    <pre data-bind="text: ko.toJSON($data, null, 2)"></pre>
</div>

JSFidde:http://jsfiddle.net/wLbV6/

1 个答案:

答案 0 :(得分:6)

您没有使用ko.mapping.fromJS函数的正确重载。

你需要写:

ko.mapping.fromJS(item, {} /* mapping options */, this);

演示JSFiddle

ko.mapping.fromJS函数仅适用于仅提供两个参数,如果第二个参数是已经由插件映射的对象,那么它具有"__ko_mapping__"属性。

您可以在此处详细了解不同的重载:Unable to parse bindings js error using ko.mapping.fromJSON with parse exist view model