- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我已经开始学习 Angular2,但在使用发射/订阅的自定义事件方面遇到了问题。
我创建了一个小演示来演示:Plunker
如您所见,有一个 PreviewService 类。这个类有一个 setURL(url: string) 方法,如果被调用,它会发出一个 contentUrlChange$ 事件。
src/services/preview.service.ts
import {Injectable, EventEmitter} from 'angular2/core';
@Injectable()
export class PreviewService {
private _url: string;
contentUrlChange$: EventEmitter<any>;
constructor() {
this.contentUrlChange$ = new EventEmitter;
};
setURL(url: string): void {
this._url = url;
this.contentUrlChange$.emit(url);
};
}
在 App 组件的构造函数中,我订阅了 PreviewService 的 contentUrlChange$ 事件。如果您运行 Plunker,您将看到警报窗口。
src/app.ts
[...]
constructor(private _previewService: PreviewService) {
_previewService.contentUrlChange$.subscribe(url => {
alert("APP " + url);
})
_previewService.setURL('http://www.example.com');
};
[...]
但这是我的问题:我有另一个组件 PreviewComponent,在该组件的构造函数中,就像在 App 组件的构造函数中一样,我订阅了 PreviewService 的 contentUrlChange$ 事件。但奇怪的是,应该出现的警告窗口并没有出现。
src/component/preview.component.ts
constructor(private _previewService: PreviewService) {
_previewService.contentUrlChange$.subscribe(url => {
alert("PREVIEW " + url); // Nothing happens here
})
};
我通读了几个问题/答案,这表明我正在做的事情应该有效,但仍然没有成功。任何想法/解决方案将不胜感激。谢谢。
最佳答案
您的笨拙几乎没有问题。首先,如果您向组件注入(inject)单独的服务实例,它们将无法订阅相同的事件,原因很简单,因为它们是不同的变量(属性)。因此,您必须为每个组件提供相同的服务,只需在应用程序的 Bootstrap 中执行:
bootstrap(App, [
YourService
]).catch(...)
其次,当子组件 (PreviewComponent
) 尚未初始化时,您正在从应用程序组件发出值。要等待,您可以使用 setTimeout(func, 0)
(但这是 hack,我不推荐这样做),或者简单地使用内置的 angular 的 OnInit
生命周期钩子(Hook)
import {OnInit} from 'angular2/core';
...
ngOnInit() {
// emit values here
}
关于typescript - Angular 2 : Cannot subscribe to custom events emitted from shared service,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34978455/
我在大学学习C++时学习了这段代码..后来我在C#中使用了同样的东西...但现在我想在Java中使用它...我在互联网上寻找类似的东西,但我什至不知道如何表达它,以便我得到正确的结果。 所以嗯,请让我
我正在我的 Ruby on Rails Controller 上运行 RSPEC 测试,这是我正在测试的 Controller 操作: Controller 代码: class Customers::
想为我选择的选项卡设置自定义背景,到目前为止,子类化是我自定义 UITAbBar/UITabBarItem 的方式。 问题是:有谁知道(或知道我在哪里可以找到)设置背景的属性是什么? 所选选项卡周围有
您好,我在 commerefacades-beans.xml 中创建了 eProductForm bean,我添加了 ProductData 的自定义属性。 然后在commercewebs
我有两个表:1. 客户2. customer_order 客户表包含客户数据(duh),customer_order 包含所有订单。我可以在 customer.id=customer_order.id
在我的 TableView 中,我有一个 NSMutableArray *currList 的数据源 - 它包含对象 Agent 的对象。我创建了自定义的 TableCell 并正确设置了所有内容。我
是否建议使用自引用泛型继承? public abstract class Entity { public Guid Id {get; set;} public int Version
我正在尝试为我的 Grafana 安装使用自定义文件 ( custom.ini )。不幸的是,这不起作用。 我做了什么: 安装了一台装有 CentOS 7 的虚拟机 添加了 Grafana Yum R
我被分配了两个给定类的作业,一个是抽象父类 Lot.java,另一个是测试类 TestLots.java。我不应该编辑其中任何一个。任务是创建Lot的两个子类,使TestLots中的错误不再是错误。
我是 Botpress 的新手。 我刚刚安装了 Botpress 的最新版本“botpress-ce-v11_0_1-win-x64”。 我浏览了文档,发现了一些关于内容类型、内容元素和内容渲染的解释
我一直在四处寻找,但我还没有找到任何东西,除了 Qt3 的旧文档和 qt 设计器的 3.x 版。 我会举个例子,并不是因为我的项目是 GPL 而不能提供代码,而是为了简单起见。 示例:您正在为您的应用
场景 我有一个自定义规则来验证订单的运费: public class OrderValidator : BaseValidator { private string CustomInfo {
我有用于身份验证的自定义拦截器: @Named("authInterceptor") @Provides @Singleton fun providesAuthIntercep
如果有人没有添加照片,我想显示默认头像图像。我假设我需要在模型或助手中执行自定义 getter。 如果我做 getter,它会看起来像这样吗: def avatar_url "default_ur
我正在使用 Google Search API,但遇到了一些麻烦。这个请求(在 Python 中,使用 requests 库)工作正常 res = requests.get("https://www.
我使用 MSKLC 制作了自定义键盘布局。 我以为我仔细按照说明操作了chose appropriate values对于LOCALENAME和 LOCALID参数。 但是,在通过按 Win+Spac
我正在使用 simpleframework解析 XML 字符串并将其转换为对象。 Serializer serializer = new Persister(); try { Customer
我正在使用 C# 控制台应用程序从 MySql 数据库获取一些数据,但在正确查询时遇到一些问题 现在的情况: SELECT * FROM Customer WHERE EXISTS ( SELECT
我在我的 iPhone 4S 上运行我的应用程序,我正在使用自定义表格 View Controller 和自定义表格 View 单元格,当我将表格 View 向上滑动到空白区域并同样向下滑动到空白区域
我有一个自定义的 JavaScript 变量,它正在检查 eventAction 是什么,这样我就可以知道是否触发一些转换像素。自定义 Javascript 称为“FacebookConversion
我是一名优秀的程序员,十分优秀!