抽屉辅助类

基于 NzDrawerService 封装,它解决一些已知问题:

  • 更友好的处理回调

  • 响应式处理

create

this.drawerHelper.create('Edit', FormEditComponent, { i }).subscribe(res => this.load());
// 对于组件的成功&关闭的处理说明
// 成功
this.NzDrawerRef.close(data);
this.NzDrawerRef.close(true);
// 关闭
this.NzDrawerRef.close();
this.NzDrawerRef.close(false);

// 关闭所有已打开的抽屉
this.DrawerHelper.closeAll();

包括 create & static 分别用于打开普通或静态抽屉。

自定义组件HTML模板

内容
<div class="drawer-footer">
  // 底部工具条由 `drawer-footer` 包裹
  <button nz-button [nzType]="'default'" (click)="cancel()">
    Cancel
  </button>
  <button nz-button [nzType]="'primary'" (click)="ok()">
    OK
  </button>
</div>

若无需要底部工具条,需要指定参数 footer: false

代码演示

基础样例

最简单的用法。

expand code expand code
import { Component } from '@angular/core';

import { DemoDrawerComponent } from '@shared';

import { DrawerHelper } from '@yelon/theme';
import { NzButtonModule } from 'ng-zorro-antd/button';
import { NzMessageService } from 'ng-zorro-antd/message';

@Component({
  selector: 'theme-drawer-simple',
  template: `
    <button nz-button (click)="open()">Open</button>
    <button nz-button (click)="static()">Static</button>
  `,
  standalone: true,
  imports: [NzButtonModule]
})
export class ThemeDrawerSimpleComponent {
  constructor(
    private modalHelper: DrawerHelper,
    private msg: NzMessageService
  ) {}

  open(): void {
    this.modalHelper.create('View', DemoDrawerComponent, { record: { a: 1, b: '2', c: new Date() } }).subscribe(res => {
      this.msg.info(res);
    });
  }

  static(): void {
    this.modalHelper.static('View', DemoDrawerComponent, { record: { a: 1, b: '2', c: new Date() } }).subscribe(res => {
      this.msg.info(res);
    });
  }
}

API

名称类型默认值功能
size指定抽屉大小,响应式只支持非数字值,若值为数值类型,则根据 nzPlacement 自动转化为 nzHeightnzWidthsm,md,lg,xl,numbermd
footer是否需要工具条booleantrue
footerHeight工具条高度number55
exact是否精准(默认:true),若返回值非空值(nullundefined)视为成功,否则视为错误booleantrue
drawerOptions抽屉 NzDrawerOptions 参数NzDrawerOptions-

Method

  • closeAll 关闭所有已打开的抽屉

Loading...