使用Knockout在Asp.Net中绑定日期

时间:2016-06-08 06:14:57

标签: javascript c# asp.net knockout.js bootstrap-datetimepicker

我在从数据库中获取数据时在beatpicker中绑定datetime时遇到问题。在选择器中,它呈现为:" /日期(1465323300000)/" ,KOJS:

DematRenounced.js

 if (obj.ResponseData != null) {
                                                 if (obj.ResponseData.length > 0) {
                                                     var DematRenouncedEntry = obj.ResponseData[0];

                                                     self.entrydate(DematRenouncedEntry.entrydate);

                                             }

和查看方式:

DematRenouncedEntry.aspx

  <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" />

3 个答案:

答案 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