1

在我的角度应用程序中,我正在调用 WCF REST 服务,它返回一个数组 ob 对象,其中一个属性是 DateTime 类型,它以这种形式在 JSON 中序列化

[{"date":"\/Date(1295164800000-0800)\/",...

为了在我的模板中很好地显示它,我创建了一个过滤器来将该 JSON 表示形式转换为 JavaScript Date 对象。

eventsApp.filter("fromMSDate", function(){
   return function (jsonDate) {
       var D, dtime, T, tz, off,
           dobj = jsonDate.match(/(\d+)|([+-])|(\d{4})/g);
       T = parseInt(dobj[0]);
       tz = dobj[1];
       off = dobj[2];
       if (off) {
           off = (parseInt(off.substring(0, 2), 10) * 3600000) +
               (parseInt(off.substring(2), 10) * 60000);
           if (tz == '-') off *= -1;
       }
       else off = 0;
       return new Date(T + off).toUTCString();
   }
});

我用这种方式

            <span class="span1">Date:</span>
            <span>{{event.date | fromMSDate}}</span>

所有工作都按需要进行,我确实在页面中显示了一个 JS Date 对象,但我不喜欢这种格式,所以我尝试应用'date'过滤器但没有成功。

            <span class="span1">Date:</span>
            <span>{{event.date | fromMSDate | date:'medium'}}</span>

由于date某种原因,过滤器被忽略,日期显示为Fri, 15 Mar 2013 00:00:00 GMT

我在这里做错了什么?

谢谢

4

1 回答 1

2

Date.prototype.toUTCString以 Angular 的日期过滤器无法识别的格式(“星期一,2006 年 7 月 3 日 21:44:38 GMT”)返回日期。

从日期过滤器文档

[Param date:] 日期格式化为 Date 对象、毫秒(字符串或数字)或各种 ISO 8601 日期时间字符串格式(例如 yyyy-MM-ddTHH:mm:ss.SSSZ 及其较短的版本,如 yyyy-MM-ddTHH:mmZ , yyyy-MM-dd 或 yyyyMMddTHHmmssZ)。如果在字符串输入中未指定时区,则时间被认为是本地时区。

因此,要生成日期过滤器可以理解的格式,该格式以日期过滤Date.prototype.toISOString器兼容格式(“2013-10-31T08:36:14.601Z”)生成日期。

app.controller('AppCtrl', function($scope){
  $scope.jsonDate = "\/Date(1295164800000-0800)\/";
});

app.filter("fromMSDate", function(){
 return function (jsonDate) {
   var D, dtime, T, tz, off,
   dobj = jsonDate.match(/(\d+)|([+-])|(\d{4})/g);
   T = parseInt(dobj[0]);
   tz = dobj[1];
   off = dobj[2];
   if (off) {
     off = (parseInt(off.substring(0, 2), 10) * 3600000) +
           (parseInt(off.substring(2), 10) * 60000);
     if (tz == '-') off *= -1;
   }
   else off = 0;
   return new Date(T + off).toISOString();
 }
});
<div ng-controller="AppCtrl">

  <div>date json: {{jsonDate}}</div> <!-- == /Date(1295164800000-0800)/ -->
  <div>date fromMSDate: {{jsonDate | fromMSDate}}</div> <!-- == 2011-01-16T00:00:00.000Z -->
  <div>date medium: {{jsonDate | fromMSDate | date:'medium'}}</div> <!-- == Jan 16, 2011 1:00:00 AM -->
  <div>date short: {{jsonDate | fromMSDate | date:'short'}}</div> <!-- == 1/16/11 1:00 AM -->

</div>
于 2013-10-31T08:43:46.210 回答