angualr2中emit触发一个方法然后怎么获得这个promise的结果

现在写了一个direactive来代替click操作,在点击后按钮disable掉,比如click是调用登陆的方法,在登陆service的promise结束后恢复按钮。
现在可以模拟click,把按钮disabled,但是获得不到promise的结果,请问有没有什么好的方法?

//directive (大概的代码)

@Output() czClick  = new EventEmitter();
@HostListener("click",["$event"])
    onClick(e){
        this.renderer.setElementAttribute(this.element.nativeElement,'disabled','true');
        this.czClick.emit(e);
      
    }
//html
<button cz-click (czClick)="login()">登录</button>

主要就是this.czClick.emit(e);这边获得不到login的promise结果,就不能在结束状态修改button的效果。

求教0-0

阅读 4.6k
2 个回答

EventEmitter应该没办法获得获得响应结果,毕竟emit一个事件可能会有n个监听这个事件的元素

可以考虑对参数下手,emit一个{ e, callback }的对象出去,在事件响应方法里调用这个callback

更好的方法应该是在directive上加个@Input,再implements OnChanges接口,监听这个@Input属性变化
然后在component里绑定这个@Input属性吧

(czClick)="login($event)"吧?

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题