如何在Angular 6的Ngx-bootstrap模态中将组件作为模体传递

时间:2019-01-04 09:35:33

标签: angular ngx-bootstrap-modal

我在Angular 6中使用ngx-bootstrap作为模态,我创建了一个共享模态,我想在modal-body部分中添加不同的HTML模板。如何添加HTML模板或如何将动态组件传递给共享模式。

共享模式组件:

@Component({
selector: 'modal-content',
template: `
<div class="modal-header">
  <h4 class="modal-title">{{headerText}}</h4>
</div>
  <div *ngIf="showTemplate" class="modal-body">
   <templateselector></templateselector>
 </div>
<div class="modal-footer">
  <button  type="button" class="btn btn-primary" (click)="clickOk()"> 
  {{actionButtonText}}</button>
</div>
`
 })
export class ModalContentComponent{
 headerText: string; 
 actionButtonText: string;
 showTemplate: boolean;
 templateselector: any;  

 constructor(public bsModalRef: BsModalRef) { }

 clickOk() {
    this.bsModalRef.hide();
 }

呼叫组件:

@Component({
selector: 'modal-content',
template: `
   <div>
  <button type="button" class="btn" 
  (click)="openModalWithComponent()">modal</button>
   </div>`
  })

export class DynamicComponent{

constructor(public bsModalRef: BsModalRef) { }

openModalWithComponent(message: string, title: string) {
    const initialState = {
        headerText: title, 
        actionButtonText: "Continue",
        showTemplate: true,
        templateSelector : NewComponent //From here i need to pass different 
        //HTML which should get load in Modal body.
};
    this.bsModalRef = this.modalService.show(ModalContentComponent, { 
    initialState });

}

从调用组件中,我应该能够传递组件的名称,我不想对选择器进行硬编码,因为这些组件将要更改,并且该组件以及模态页眉和页脚都应加载。

1 个答案:

答案 0 :(得分:0)

代替

this.bsModalRef = this.modalService.show(ModalContentComponent, { initialState });

您可能要去掉方括号,而只是将该对象用作第二个参数:

this.bsModalRef = this.modalService.show(ModalContentComponent, initialState);