JSON.stringify一个具有Knockout JS变量的对象

时间:2013-02-26 11:18:03

标签: javascript json knockout.js

当前情况:

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字符串。如果没有可观察的信息,这很容易做到,有没有一种简单的方法可以用它们来做?

3 个答案:

答案 0 :(得分:41)

Knockout有一个内置的toJSON函数来完成这个:

var json = ko.toJSON(viewModel);
  

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

答案 1 :(得分:5)

您可以通过以下两种方式执行此操作:

第一

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

第二

      var json = JSON.stringify(ko.mapping.toJS(viewModel))

答案 2 :(得分:3)

你看过knockout mapping plugin吗?

var unmapped = ko.mapping.toJS(viewModel);