我在从数据库中获取数据时在beatpicker中绑定datetime时遇到问题。在选择器中,它呈现为:" /日期(1465323300000)/" ,KOJS:
if (obj.ResponseData != null) {
if (obj.ResponseData.length > 0) {
var DematRenouncedEntry = obj.ResponseData[0];
self.entrydate(DematRenouncedEntry.entrydate);
}
和查看方式:
<input type="text" id="txtEntryDate" data-beatpicker="true" class="form-control"
data-bind="value:entrydate" maxlength="10" onblur="return valFutureDate(this,'Y',true);"
onpaste="return false" onkeypress="return isNumberKey(event)"
placeholder="YYYY.MM.DD" />
答案 0 :(得分:2)
从服务器返回的数据显然是使用Microsoft JsonSerializer序列化的,它在序列化DateTime属性时使用非标准格式。有关详细信息,请参阅此答案:https://stackoverflow.com/a/726869/4602079。
在对客户端上的日期执行任何操作之前,您需要做的是将其解析为日期。在您的情况下,您可以按如下方式修改DematRenounced.js:
self.entrydate(new Date(parseInt(DematRenouncedEntry.entrydate.replace("/Date(", "").replace(")/",""), 10)));
答案 1 :(得分:0)
按照Maciej Grzyb的回答,最后我得到了解决方案。
var t = new Date(parseInt(DematRenouncedEntry.entrydate.replace("/Date(", "").replace(")/", ""), 10));
var m = t.getMonth();
var d = t.getDate();
function addZ(m) { return m < 10 ? '0' + m : '' + m; };
function addZy(d) { return d < 10 ? '0' + d : '' + d; };
var y = t.getFullYear();
var format = y + "." + addZ(m) + "." + addZy(d);
self.entrydate(format);
答案 2 :(得分:0)
我看看这个: https://stackoverflow.com/a/18555136/1455010
更改Json转换器以格式化ISO格式的日期:2016-06-16T18:52:36 + 00:00