为什么Angular日期过滤器显示错误的日期?

wit*_*ers 17 angularjs

我正在使用日期输入字段,并使用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>
Run Code Online (Sandbox Code Playgroud)

JS:

var app = angular.module('miniapp', []);
Run Code Online (Sandbox Code Playgroud)

我有一个小提琴演示了这个问题:http://jsfiddle.net/wittersworld/uY3s9/

编辑:我用一个有效的解决方案更新了小提琴:http://jsfiddle.net/wittersworld/uY3s9/2/

Ray*_*oal 15

这是一个时区问题.

如果您将2013年6月8日的日期输入日期选择器,那就是格林威治标准时间午夜.如果你住在英格兰西部,比如说,在美国,那就是2013年6月7日.

改变线

{{ startDate | date:'fullDate' }}
Run Code Online (Sandbox Code Playgroud)

{{ startDate | date:'medium' }}
Run Code Online (Sandbox Code Playgroud)

看时间!

  • 工作链接:http://www.techrepublic.com/article/convert-the-local-time-to-another-time-zone-with-this-javascript/ (2认同)