19

当前情景:

function Employee(data) {
var self = this;

// variables
this.Forename = ko.observable(data.Forename);
this.Surname = ko.observable(data.Surname);

this.Save = function () {
    var obj = JSON.stringify(self); // Without ko.observables, this works fine. self() doesn't work obviously.
    console.log(obj);
};
}

我认为我正在尝试做的事情非常简单,获取所有可观察值而无需遍历每一个值,并使用 stringify 函数创建一个 JSON 字符串。这很容易在没有 observables 的情况下做到,有没有一种简单的方法可以用它们来做到这一点?

4

3 回答 3

45

Knockout 有一个内置的toJSON函数可以做到这一点:

var json = ko.toJSON(viewModel);

ko.toJSON — 这会生成一个 JSON 字符串,代表您的视图模型的数据。在内部,它只是在视图模型上调用 ko.toJS,然后在结果上使用浏览器的原生 JSON 序列化程序。注意:要在没有原生 JSON 序列化程序的旧浏览器(例如,IE 7 或更早版本)上运行,您还必须引用 json2.js 库。

于 2013-02-26T11:24:07.570 回答
5

您可以通过 2 种方式做到这一点:

第一的:

      var json = ko.toJSON(ko.mapping.toJS(viewModel))

第二

      var json = JSON.stringify(ko.mapping.toJS(viewModel))
于 2013-02-26T11:29:04.810 回答
3

你看过淘汰赛映射插件吗?

var unmapped = ko.mapping.toJS(viewModel);
于 2013-02-26T11:19:21.453 回答