首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >将JSON映射到可观察数组的Knockout.js

将JSON映射到可观察数组的Knockout.js
EN

Stack Overflow用户
提问于 2012-06-07 04:21:56
回答 1查看 24.1K关注 0票数 17

我想使用Knockout.js为我的REST服务构建一个客户端。我有很多Repositorys想要通过不同的urls访问-所以我想出了这个解决方案,使用了different Prototype-Pattern。我的问题:我找不到如何将ItemsProperty与我从我的服务接收的“数据”进行映射。

代码语言:javascript
复制
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);,但我找不到正确的方法。

wrong :我做错了什么?我找到了一个例子--我想他们也在做同样的事情:http://jsfiddle.net/jearles/CGh9b/

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-06-07 05:10:55

我相信fromJS的双参数版本只用于先前映射的对象,即它们有一个隐式的空映射选项对象。由于您的映射是第一次运行,因此它需要像这样提供空的options对象。

代码语言:javascript
复制
ko.mapping.fromJS(data, {}, self.Items);

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

希望这能有所帮助。

票数 31
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10921654

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档