首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >角2 ES6/7事件发射器更新其他组件

角2 ES6/7事件发射器更新其他组件
EN

Stack Overflow用户
提问于 2016-03-27 20:24:21
回答 1查看 242关注 0票数 0

我想在组件之间共享数据,所以我实现了一个具有EventEmitter的服务。

我的服务是这样的:

代码语言:javascript
复制
@Injectable()
export class LanguageService {



  constructor() {
    this.languageEventEmitter = new EventEmitter();
    this.languages = [];

    this.setLanguages();
  }

  setLanguages() {

    var self = this;

    axios.get('/api/' + api.version + '/' + api.language)
      .then(function (response) {
        _.each(response.data, function (language) {
          language.selected = false;
          self.languages.push(language);
        });
        self.languageEventEmitter.emit(self.languages);
      })
      .catch(function (response) {
      });
  }

  getLanguages() {
    return this.languages;
  }

  toggleSelection(language) {
    var self = this;
    language.selected = !language.selected;
    self.languages.push(language);
    self.languageEventEmitter.emit(self.languages);
  }

}

我必须使用组件,这些组件订阅的服务如下:

代码语言:javascript
复制
self.languageService.languageEventEmitter.subscribe((newLanguages) => {
  _.each(newLanguages, function (language) {
    self.updateLanguages(language);
  });
});

在加载两个组件时,语言数组将按我的意愿填充。

这是第一个组成部分:

代码语言:javascript
复制
export class LanguageComponent {

  static get parameters() {
    return [[LanguageService]];
  }

constructor(languageService) {
  var self = this;

  this.languageService = languageService;
  this.languages = [];

  this.setLanguages();
}

setLanguages() {

  var self = this;

  self.languageService.languageEventEmitter.subscribe((newLanguages) => {
    _.each(newLanguages, function (language) {
      self.updateLanguages(language);
    })
  });

}

updateLanguages(newLanguage) {
  var self = this;

  if (!newLanguage) {
    return;
  }

  var match = _.find(self.languages, function (language) {
    return newLanguage._id === language._id;
  });

  if (!match) {
    self.languages.push(newLanguage);
  }

  else {
    _.forOwn(newLanguage, function (value, key) {
      match[key] = value;
    })
  }

  toggleLanguageSelection(language) {
    var self = this;
    self.languageService.toggleSelection(language)
  }

}

当LanguageComponent执行由单击事件触发的函数toggleLanguageSelection()时,另一个组件订阅如下所示:

代码语言:javascript
复制
self.languageService.languageEventEmitter.subscribe((newLanguages) => {
  _.each(newLanguages, function (language) {
    self.updateLanguages(language);
  })
});

没有得到任何改变。我认为这是因为两个组件都得到了我的LanguageService的一个不同的实例,但我不确定。我也试图创建一个单例,但角‘2 di不再工作了。这个问题的原因是什么,如何解决呢?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-03-27 21:30:12

在引导应用程序时,需要定义共享服务:

代码语言:javascript
复制
bootstrap(AppComponent, [ SharedService ]);

而不是在组件的providers属性中再次定义它。这样,您将拥有整个应用程序的一个服务实例。组件可以利用它来进行通信。

这是因为Angular2的“分层注入器”特性。有关更多细节,请参见以下问题:

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/36252236

复制
相关文章

相似问题

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