javascript - AngularJS 日期过滤器添加了意外的时区偏移?

标签 javascript angularjs datetime timezone timezone-offset

文档:https://docs.angularjs.org/api/ng/filter/date

骗子:https://plnkr.co/edit/q6KPNejv52SzewDlvGyu?p=preview

代码片段如下:

var app = angular.module("app", []);

app.controller("ctrl", function($scope, $interval) {
    $scope.message = "It works!";
    $scope.dateStart = new Date();
    
    $interval(function() {
      $scope.dateNow = new Date();
    }, 42)
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.6.9/angular.min.js"></script>
<div ng-app="app" ng-controller="ctrl">
    {{ message }} <br>
    
    {{ dateNow - dateStart | date: 'hh:mm:ss:sss' }} <br>
    
    {{ dateNow - dateStart | date: 'hh:mm:ss:sss' : 'UTC' }} <br>
    
</div>

  • 无时区 - 将 01 显示为小时。
  • UTC 作为时区传递 - 将 12 显示为小时。

在我的其他项目中,我想出了这个解决方法...感觉很糟糕,我不想复制粘贴垃圾代码。当然有更好的方法吗?

(也许我应该只使用 moment, bundle 大小在这里并不重要)

app.filter('mydate', function(){
  return function(text, extra) {
    // https://stackoverflow.com/a/39209842/775359
    var date = new Date(text)
    var userTimezoneOffset = date.getTimezoneOffset() * 60000;
    var newdate = new Date(date.getTime() + userTimezoneOffset);

    return pad(newdate.getHours(),2) + ":" + pad(newdate.getMinutes(),2) + ":" + pad(newdate.getSeconds(),2) 
           + (extra ? ":" + pad(newdate.getMilliseconds(), 3) : "");
  };
});

app.filter('pad', [function(){
  return function(text, width) { 
    return pad(text, width)
  };
}]);

function pad(text, width) { 
  text = text + ''; // converting to string because if we pass number it will fail
  return text.length >= width ? text : new Array(width - text.length + 1).join('0') + text;
};
<小时/>

不是解决方案:AngularJS global Date timezone offset (默认设置GMT仍显示为12小时)

可能重复:AngularJs filter date adding 2 hours (未回答)

最佳答案

使用日期:'HH:mm:ss:sss':'UTC'使用国会大厦HH:

var app = angular.module("app", []);

app.controller("ctrl", function($scope, $interval) {
    $scope.message = "It works!";
    $scope.dateStart = new Date().valueOf();
    
    $interval(function() {
      $scope.dateNow = new Date().valueOf();
    }, 42)
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.6.9/angular.min.js"></script>
<div ng-app="app" ng-controller="ctrl">
    {{ message }} <br>
    
    {{ dateNow - dateStart | date: 'HH:mm:ss:sss' : 'UTC' }} <br>
    
</div>

格式字符串可以由以下元素组成:

  • “HH”:一天中的小时,填充 (00-23)
  • “H”:一天中的小时 (0-23)
  • 'hh':AM/PM 中的小时,填充 (01-12)
  • 'h':AM/PM 中的小时,(1-12)

欲了解更多信息,请参阅

关于javascript - AngularJS 日期过滤器添加了意外的时区偏移?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59173906/

相关文章:

javascript - jquery中整数和小数的简单计算

javascript - 我无法理解我的 If 陈述如何被视为真实

javascript - 是否可以在没有node.js的情况下使用socket.io?

bash - Bash 中的组合日期和时间表示

javascript - React 无法读取属性值

angularjs - Angular Http 优先级

javascript - 如何使用 ng-options 在选择框中选择默认时间值

angularjs - 如何在运行时处理 'get'请求中的错误?

c# - 如何解析 d/y/year 的日期格式?

c# - Html.HiddenFor 在 ASP.NET 中错误地格式化 DateTime