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/

Надеюсь это поможет.

Другие вопросы по тегам