微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何使用自定义按钮配置创建可重用组件

如何解决如何使用自定义按钮配置创建可重用组件

因此,目前我有一个组件,该组件具有可通过选项配置的多个按钮:

test.component.html

<button
    *ngIf="cleaning"
    (click)="onCleaning()"
>
    {{'btn.cleaning'|translate}}
</button>

<button
    *ngIf="remove"
    (click)="onRemoving()"
>
    {{'btn.remove'|translate}}
</button>

test.component.ts

@input() cleaning: boolean;
@input() remove: boolean;
cleaningForm: FormGroup;

parent.component.html

<test [cleaning]="true" [remove]="false"></test>

想法是,此组件更大且可重用,其中只有要按下的按钮和操作会发生变化,但始终需要表单。

是否还有其他更好的解决方案来获取此类组件,以某种方式在父组件中使用ng-content和触发形式?

解决方法

不确定是否要提供所有按钮及其(单击)方法,或者该组件是否应该仅凭很少的逻辑简单地执行给定的输入。如果您想使用给定的按钮来设置可重用样式的组件(如弹出窗口),则后者很有趣。

您不仅可以提供元素,还可以提供其功能。

Parent.ts

export class ParentComponent implements OnInit {
  public cbFunction: (e: MouseEvent) => void //or whatever return value

  public ngOnInit(): void {
    this.cbFunction = ((e: MouseEvent) => { this.doFancyStuff(); }).bind(this);
  }
}

Parent.html

<child [callback]="cbFunction" name="cbFktBtn"></child>

Child.ts

export class ChildComonent {
   @Input() callback: (e: MouseEvent) => void;
   @Input() name: string;
}

Child.html

<button (click)="callback($event)">{{name}}</button>

这显然也适用于按钮数组(或集合或地图等)。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。