【发布时间】:2015-10-21 13:56:36
【问题描述】:
我的视图模型是这样的:
var viewModel = function(){
var self = this;
self.title = ko.observable('Hello World');
self.rows = ko.observableArray();
self.on_click = function(){
alert('Hello World');
var data = [
{
id : 1,
x : 1,
y : 2,
z : 3,
},
{
id : 2,
x : 4,
y : 5,
z : 6,
},
{
id : 3,
x : 7,
y : 8,
z : 9,
}
];
self.rows(ko.unwrap(ko.mapping.fromJS(data, viewModelRow)));
alert(self.rows());
};
};
var viewModelRow = function(){
var self = this;
self.id = ko.observable();
self.x = ko.observable();
self.y = ko.observable();
self.z = ko.observable();
self.mthd = function(){
alert('Just Clicked');
};
};
vm = new viewModel();
ko.applyBindings(vm);
我的html是这样的:
<body>
<h1 data-bind="text:title"></h1>
<div data-bind="foreach: rows">
<table>
<tr>
<td data-bind="text : id"></td>
<td data-bind="text: x"></td>
<td data-bind="text: y"></td>
<td data-bind="text: z"></td>
<td><button type="button" data-bind="click: mthd">btn</button></td>
</tr>
</table>
</div>
<button type="button" data-bind="click: on_click">button</button>
</body>
当使用 viewModelRow 视图模型上的数据执行映射时,它会抛出错误提示
ReferenceError: mthd is not defined
我希望在 viewModelRow 中定义所有带有 viewModelRow 的 json 数据映射以及名为 mthd 的方法。 请帮忙。 JSFIDDLE 链接:http://jsfiddle.net/enabqm3d/5/
【问题讨论】:
标签: knockout.js knockout-mapping-plugin