Knockout.js, отображающий JSON в наблюдаемый массив
Я хочу собрать клиент для моего REST-сервиса, используя Knockout.js. У меня есть много репозиториев, к которым я хочу получить доступ через разные URL-адреса - поэтому я пришел к этому решению, используя шаблон Revealing-Prototype-Pattern. Моя проблема: я не могу узнать, как сопоставить ItemsProperty с моими "данными", которые я получаю от своего сервиса.
var Repository = function (url) {
this.Url = url;
this.Items = ko.observableArray([]);
this.PendingItems = ko.observableArray([]);
};
Repository.prototype = function () {
var
getAllItems = function () {
var self = this;
$.getJSON(self.Url, function (data) {
// data=[{"Id":1,"Name":"Thomas","LastName":"Deutsch"},{"Id":2,"Name":"Julia","LastName":"Baumeistör"}]
ko.mapping.fromJS(data, self.Items);
});
},
...
// i call it like this:
customerRepository = new Repository('http://localhost:9200/Customer');
customerRepository.getAllItems();
Я думаю, что проблема заключается в следующем: ko.mapping.fromJS (data, self.Items); но я не могу найти правильный способ сделать это.
Вопрос: что я делаю не так? я нашел пример - и они делают то же самое, я думаю: http://jsfiddle.net/jearles/CGh9b/
1 ответ
Я полагаю, что версия fromJS с двумя аргументами используется только для объектов, которые были ранее отображены, то есть у них был неявный пустой объект параметров отображения. Так как ваше сопоставление выполняется впервые, оно должно предоставить провайдеру такой пустой объект параметров.
ko.mapping.fromJS(data, {}, self.Items);
http://jsfiddle.net/madcapnmckay/j7Qxh/1/
Надеюсь это поможет.