我正在使用日期输入字段,并使用Angular格式化我的ui中的所选日期。但格式化日期始终比所选日期少1天。为什么会这样,我该如何解决?
HTML:
<div ng-app="miniapp">
<div>
<label class="control-label" for="inputStart">Start Date:</label>
<input type="date" id="inputStart" data-ng-model="startDate" /><br />
Selected: <span>{{ startDate }}</span><br />
fullDate: <span>{{ startDate | date:'fullDate' }}</span><br />
mediumDate: <span>{{ startDate | date:'mediumDate' }}</span><br />
MMMM d yyyy<span>{{ startDate | date:'MMMM d yyyy' }}</span>
</div>
</div>
JS:
var app = angular.module('miniapp', []);
我有一个小提琴演示了这个问题:http://jsfiddle.net/wittersworld/uY3s9/
编辑:我用工作解决方案更新了小提琴:http://jsfiddle.net/wittersworld/uY3s9/2/
答案 0 :(得分:15)
这是一个时区问题。
如果您在日期选择器中输入2013年6月8日的日期,那就是格林威治标准时间午夜。如果你住在英格兰西部,比如在美国,那就是2013年6月7日。
更改行
{{ startDate | date:'fullDate' }}
到
{{ startDate | date:'medium' }}
看时间!