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来处理日期对象?
鉴于 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。
| 归档时间: |
|
| 查看次数: |
5935 次 |
| 最近记录: |