Я пытаюсь добавить функцию к кнопке в моей форме. Я продолжаю получать сообщение о том, что alertMe не определен.
Я попытался объявить свое сопоставление как таковое:
$(function () {
var mapping = {
create: function (options) {
return new CsvImportItem(options.data);
},
alertMe: function () {
alert('Here we go');
}
}
var CsvImportItem = function (data) {
ko.mapping.fromJS(data, {}, this);
this.rowClass = ko.computed(function () {
if (this.Accepted()) return 'success'; else return 'error';
}, this);
this.acceptItem = function () {
this.Accepted(true);
};
this.declineItem = function () {
this.Accepted(false);
};
}
var viewModelJSON = ko.mapping.fromJS($.parseJSON('@Html.Raw(jsonData)'), mapping);
ko.applyBindings(viewModelJSON);
});
Если я изменю viewModelJSON на:
var viewModelJSON = ko.mapping.fromJS($.parseJSON('@Html.Raw(jsonData)'), {}, mapping);
то вызов функции alertMe работает, а остальные элементы отображения — нет. Любые мысли о том, что я делаю неправильно?
Обновить, чтобы показать структуру данных
Моя структура данных, поступающая в представление, имеет тип
IEnumberable<Project.Namespace.CsvImportItem>
Поэтому я получаю такую структуру:
[
{CsvImportItem},
{CsvImportItem},
{CsvImportItem}
]
alertMe
? Зачем просто помещать определениеalertMe
в объектCsvImportItem
? - person nemesv   schedule 27.11.2012