Knockout.js, отображающий JSON в наблюдаемый массив - программирование
Подтвердить что ты не робот

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/

4b9b3361

Ответ 1

Я считаю, что две аргумента-версии fromJS используются только для объектов, которые были ранее отображены, т.е. у них был объект неявного пустого отображения. Поскольку ваше сопоставление выполняется в первый раз, он должен предоставить этот пустой объект таким образом.

ko.mapping.fromJS(data, {}, self.Items);

http://jsfiddle.net/madcapnmckay/j7Qxh/1/

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