ko.toJSON()是否适用于日期?

Jas*_*son 7 ajax json knockout.js

我在asp.net mvc页面上使用knockoutjs.我使用ajax通过调用将表单保存回服务器ko.toJSON(viewModel),然后使用jQuery将结果发回服务器.除了作为空对象持久化的Javascript日期之外,视图模型上的所有属性都已成功序列化.

宣言:

var viewModel = {
    startTime: ko.observable(),
    type: ko.observable(),
    durationInMinutes: ko.observable(),
    notes: ko.observable()
};
Run Code Online (Sandbox Code Playgroud)

保存数据:

var postData = ko.toJSON(viewModel); 
$.ajax({
    url: "/data",
    type: "POST",
    data: postData,
    dataType: "json",
    contentType: "application/json; charset=utf-8",
    success: function () {
        console.log('success!');
    },
    error: function () {
        console.log('fail!');
    }
});
Run Code Online (Sandbox Code Playgroud)

viewModel.startTime()的console.log值是:

Date {Tue May 10 2011 11:30:00 GMT-0500 (Central Daylight Time)}

保存数据的第1行之后,postData的值为:

{
    "startTime": {},
    "type": "1",
    "durationInMinutes": "45",
    "notes": "asfasdfasdfasdfasdfasdfasdfas",
    "displayableStartTime": "10-May 11:30"
}
Run Code Online (Sandbox Code Playgroud)

如果我将保存数据的第1行展开到

var jsonEvent = ko.toJS(viewModel);
jsonEvent.startTime = viewModel.startTime();
var postData = JSON.stringify(jsonEvent);
Run Code Online (Sandbox Code Playgroud)

postData的值是:

{
    "startTime": "2011-05-10T16:30:00.000Z",
    "type": "1",
    "durationInMinutes": "45",
    "notes": "asfasdfasdfasdfasdfasdfasdfas",
    "displayableStartTime": "10-May 11:30"
}
Run Code Online (Sandbox Code Playgroud)

任何人都可以解释可能会发生什么,以及我如何能够获得knockoutjs来处理日期对象?

RP *_*yer 3

鉴于 ko.toJS 和日期的当前问题,一种选择是创建一个 dependentObservable ,其中包含您希望服务器处理的实际值。

就像是:

var viewModel = {
    startTimeForInput: ko.observable(),
    type: ko.observable(),
    durationInMinutes: ko.observable(),
    notes: ko.observable()
};

viewModel.startTime = ko.dependentObservable(function() {
    return this.startTimeForInput().toJSON();
}, viewModel);

ko.applyBindings(viewModel);
Run Code Online (Sandbox Code Playgroud)

现在,当您调用时,ko.toJSON您将获得startTime服务器可以使用的正确值。

对于较旧的浏览器,类似json2.js 的内容将包含 Date 对象的 .toJSON。