错误消息
org.codehaus.jackson.map.JsonMappingException:无法从字符串值'02 / 23/2013'构造java.util.Date的实例:不是有效的表示形式(错误:无法解析日期“02/23 / 2013“:与任何标准形式不兼容(”yyyy-MM-dd'T'HH:mm:ss.SSSZ“,”yyyy-MM-dd'T'HH:mm:ss.SSS'Z'“, “EEE,dd MMM yyyy HH:mm:ss zzz”,“yyyy-MM-dd”))
Java对象 - 实体
@Column(name = "event_date")
@Temporal(TemporalType.TIMESTAMP)
private Date eventDate;
Java脚本
$(function() {
$("#datepicker").datepicker();
});
function formToJSON() {
return JSON.stringify({
"eventDate": $('#datepicker').val()
});
}
HTML
<input type="text" id="datepicker" name="date" placeholder="Date" />
答案 0 :(得分:5)
你可以这样做:
$(function() {
$("#datepicker").datepicker({
dateFormat: "yy-mm-dd"
});
});
答案 1 :(得分:2)
datepicker
包含日期格式设置实用程序$.datepicker.formatDate
API参考:http://docs.jquery.com/UI/Datepicker/$.datepicker.formatDate
试试这个:
function formToJSON() {
var d= $('#datepicker').datepicker('getDate')
return JSON.stringify({
"eventDate": $.datepicker.formatDate('yy-mm-dd', d)
});
}
答案 2 :(得分:1)
可能有更好的解决方案,但由于这是一个我经常遇到的问题而且通常找不到一个随时可用的工具,我最终为此编写了自己的函数:
function dateFormat(date) {
function two(v) { return v < 10 ? "0" + v : "" + v; }
function four(v) { return v < 10 ? "000" + v : v < 100 ? "00" + v : v < 1000 ? "0" + v : "" + v; }
var y = four(date.getFullYear());
var m = two(date.getMonth()+1);
var d = two(date.getDate());
return y + "-" + m + "-" + d;
};
function datetimeFormat(date) {
function two(v) { return v < 10 ? "0" + v : "" + v; }
function three(v) { return v < 10 ? "00" + v : v < 100 ? "0" + v : "" + v; }
function four(v) { return v < 10 ? "000" + v : v < 100 ? "00" + v : v < 1000 ? "0" + v : "" + v; }
var y = four(date.getUTCFullYear());
var m = two(date.getUTCMonth()+1);
var d = two(date.getUTCDate());
var h = two(date.getUTCHours());
var mm = two(date.getUTCMinutes());
var s = two(date.getUTCSeconds());
var ms = three(date.getUTCMilliseconds());
return y + "-" + m + "-" + d + "T" + h + ":" + mm + ":" + s + "." + ms;
};
第一个是您在特定情况下所需要的,因为您只处理日期(而不是时间)。
return JSON.stringify({
"eventDate": dateFormat($('#datepicker').datepicker('getDate'))
});