【Angular实战/网易云】模态框(二)

之前的内容我们已经简单介绍了如何生成模态框,以及用状态管理插件管理状态,并把批量的action封装成service。下面我们正式来给我们的模态框添加特性。

一. ESC键退出

简单地来说就是监听键盘上的keydown事件,如果keyCode对应的是ESC键,那就隐藏模态框。

  private createOverlay() {
    this.overlayRef = this.overlay.create();
    this.overlayRef.overlayElement.appendChild(this.elementRef.nativeElement);
    // 创建模态框的时候就开始监听
    this.overlayRef.keydownEvents().subscribe(e => this.handleKeyDownEvent(e));
  }

  private handleKeyDownEvent(evt: KeyboardEvent) {
    if (evt.keyCode === ESCAPE) {
      this.onClick();
    }
  }

另外,我们也不能一直监听,当visible为false的时候显然再监听就不合适了,所以注入OverlayKeyboardDispatcher。当visiable为true的时候add OverlayRef, 为false的时候remove OverlayRef.

  // 省略了部分代码
  private handleVisiableChange(visiable) {
    if (visiable) {
      // ....
      this.overlayKeyboardDispatcher.add(this.overlayRef);
      //
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值