是否有角日期前管道?

Jih*_*eew 6 pipe typescript angular-pipe angular

我正在尝试创建帖子共享网站。我想以角度创建日期前管道。

    import {Pipe, PipeTransform} from 'angular2/core';

@Pipe({
  name: 'messageTime',
  pure: false
})
export class MessageTimePipe implements PipeTransform {
  transform(value: Date, []): string {
    var result: string;

    // current time
    let now = new Date().getTime();

    // time since message was sent in seconds
    let delta = (now - value.getTime()) / 1000;

    // format string
    if (delta < 10) {
      result = 'jetzt';
    } else if (delta < 60) { // sent in last minute
      result = 'vor ' + Math.floor(delta) + ' Sekunden';
    } else if (delta < 3600) { // sent in last hour
      result = 'vor ' + Math.floor(delta / 60) + ' Minuten';
    } else if (delta < 86400) { // sent on last day
      result = 'vor ' + Math.floor(delta / 3600) + ' Stunden';
    } else { // sent more than one day ago
      result = 'vor ' + Math.floor(delta / 86400) + ' Tagen';
    }

    return result;
  }enter code here
}
Run Code Online (Sandbox Code Playgroud)

我在我的项目中尝试像上面的代码。但它不能正常工作。

小智 11

首先创建管道类

ng g p pipes/DateAgo
Run Code Online (Sandbox Code Playgroud)

让我们添加这些代码,

  import {Pipe, PipeTransform} from '@angular/core';

@Pipe({
    name: 'dateAgo',
    pure: true
})
export class DateAgoPipe implements PipeTransform {

    transform(value: any, args?: any): any {
        if (value) {
            const seconds = Math.floor((+new Date() - +new Date(value)) / 1000);
            if (seconds < 29) // less than 30 seconds ago will show as 'Just now'
                return 'Just now';
            const intervals = {
                'year': 31536000,
                'month': 2592000,
                'week': 604800,
                'day': 86400,
                'hour': 3600,
                'minute': 60,
                'second': 1
            };
            let counter;
            for (const i in intervals) {
                counter = Math.floor(seconds / intervals[i]);
                if (counter > 0)
                    if (counter === 1) {
                        return counter + ' ' + i + ' ago'; // singular (1 day ago)
                    } else {
                        return counter + ' ' + i + 's ago'; // plural (2 days ago)
                    }
            }
        }
        return value;
    }

}
Run Code Online (Sandbox Code Playgroud)


ben*_*oam 5

我认为这是更好地使用下面的包之一获得一个很久以前的功能,而不是创建自己的,像几个原因quick implementation/ maintenance/ new features and fixes/etc

  • ngx-timeago(将是我的选择)

    这个具有另一个没有的功能,例如 i18n、对之前文本的实时更改等。

  • 时间前管道

    这是一个简单的“仅限管道”包装,因此重量轻且易于使用。

  • ngx-时刻

    建议:仅当你已经在你的应用程序中使用 moment.js 时才使用这个,因为这将成为一个遗留项目,它会给你的包大小增加很多重量(见下面的评论,谢谢@ymerej 和 @Alexandre杰曼)。

  • 仅供参考,如果您不使用 momentjs,您的包将会膨胀约 500kb。为了这样的事情不值得。 (2认同)