发布
社区首页 >问答首页 >如何从Angular 2中的可观测对象提供LOCALE_ID?

如何从Angular 2中的可观测对象提供LOCALE_ID?
EN

Stack Overflow用户
提问于 2017-02-03 22:19:03
回答 2查看 2.2K关注 0票数 1

在Angular 2中,为了本地化日期管道,您需要提供LOCALE_ID。我有一个公开locale$: Observable<string>的服务LocaleService,它实现了BehaviorSubject<string>。我不想给这个服务添加任何状态,我希望它是完全被动的。如何在提供LOCALE_ID时从该服务获取信息

EN

回答 2

Stack Overflow用户

发布于 2017-08-15 15:44:08

如果你想为你的应用程序设置一次语言,LOCALE_ID的解决方案是很棒的。但是如果你想在运行时改变语言,它就不起作用了。请参阅我的答案here

票数 1
EN

Stack Overflow用户

发布于 2017-02-03 22:53:09

管道可以返回一个可观察对象。

代码语言:javascript
代码运行次数:0
复制
import { Pipe, PipeTransform } from '@angular/core';
import { LocaleService } from 'shared/locale.service';
import { Observable } from 'rxjs/Observable';
import { formatDate } from 'somelibrary';
import 'rxjs/add/operator/map';

@Pipe({
  name: 'myDate',
  pure: false
})
export class MyDatePipe implements PipeTransform {

  constructor(private localeService: LocaleService) { }

  transform(date: string): Observable<String> {
    return this.localeService.locale$.map(locale => formatDate(date, locale));
  }
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42026342

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档