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/
Надеюсь, что это поможет.