Ähnliche Frage hier
Ich werde meine Antwort erneut veröffentlichen und eine Zusammenführung vorschlagen:
Die Ausgabe von UTC scheint Gegenstand einiger Verwirrung zu sein - die Leute scheinen sich für moment.js zu interessieren .
Aus dieser Antwort entlehnt, könnten Sie so etwas tun (dh eine Konvertierungsfunktion verwenden, die das Datum mit dem UTC-Konstruktor erstellt), ohne moment.js:
Regler
var app1 = angular.module('app1',[]);
app1.controller('ctrl',['$scope',function($scope){
var toUTCDate = function(date){
var _utc = new Date(date.getUTCFullYear(), date.getUTCMonth(), date.getUTCDate(), date.getUTCHours(), date.getUTCMinutes(), date.getUTCSeconds());
return _utc;
};
var millisToUTCDate = function(millis){
return toUTCDate(new Date(millis));
};
$scope.toUTCDate = toUTCDate;
$scope.millisToUTCDate = millisToUTCDate;
}]);
Vorlage
<html ng-app="app1">
<head>
<script data-require="angular.js@*" data-semver="1.2.12" src="http://code.angularjs.org/1.2.12/angular.js"></script>
<link rel="stylesheet" href="style.css" />
<script src="script.js"></script>
</head>
<body>
<div ng-controller="ctrl">
<div>
utc {{millisToUTCDate(1400167800) | date:'dd-M-yyyy H:mm'}}
</div>
<div>
local {{1400167800 | date:'dd-M-yyyy H:mm'}}
</div>
</div>
</body>
</html>
Hier ist Plunker , um damit zu spielen
Siehe auch dies und das .
Beachten Sie auch, dass bei dieser Methode, wenn Sie das 'Z' aus dem Datumsfilter von Angular verwenden, Ihr lokaler Zeitzonenversatz anscheinend immer noch gedruckt wird.