Sekarang tersedia sebagai paket NPM
sudut-custom-modal
@Stephen Paul kelanjutan ...
- Sudut 2 dan lebih tinggi Bootstrap css (animasi dipertahankan)
- TANPA JQuery
- TANPA bootstrap.js
- Mendukung konten modal khusus
- Dukungan untuk banyak modals di atas satu sama lain.
- Dimodernisasi
- Nonaktifkan gulir saat modal terbuka
- Modal hancur ketika menavigasi.
- Inisialisasi konten malas, yang didapat
ngOnDestroy
(ed) saat modal keluar.
- Scrolling orangtua dinonaktifkan ketika modal terlihat
Inisialisasi konten malas
Mengapa?
Dalam beberapa kasus Anda mungkin tidak ingin modal untuk mempertahankan statusnya setelah ditutup, tetapi dikembalikan ke keadaan awal.
Masalah modal asli
Melewati konten secara langsung ke tampilan sebenarnya menghasilkan menginisialisasi bahkan sebelum modal mendapatkannya. Modal tidak memiliki cara untuk membunuh konten seperti itu bahkan jika menggunakan *ngIf
pembungkus.
Larutan
ng-template
. ng-template
tidak membuat sampai diperintahkan untuk melakukannya.
my-component.module.ts
...
imports: [
...
ModalModule
]
my-component.ts
<button (click)="reuseModal.open()">Open</button>
<app-modal #reuseModal>
<ng-template #header></ng-template>
<ng-template #body>
<app-my-body-component>
<!-- This component will be created only when modal is visible and will be destroyed when it's not. -->
</app-my-body-content>
<ng-template #footer></ng-template>
</app-modal>
modal.component.ts
export class ModalComponent ... {
@ContentChild('header') header: TemplateRef<any>;
@ContentChild('body') body: TemplateRef<any>;
@ContentChild('footer') footer: TemplateRef<any>;
...
}
modal.component.html
<div ... *ngIf="visible">
...
<div class="modal-body">
ng-container *ngTemplateOutlet="body"></ng-container>
</div>
Referensi
Saya harus mengatakan bahwa itu tidak akan mungkin terjadi tanpa dokumentasi resmi dan komunitas yang bagus di internet. Mungkin membantu sebagian dari Anda juga untuk lebih memahami bagaimana ng-template
, *ngTemplateOutlet
dan @ContentChild
bekerja.
https://angular.io/api/common/NgTemplateOutlet
https://blog.angular-university.io/angular-ng-template-ng-container-ngtemplateoutlet/
https://medium.com/claritydesignsystem/ng-content -the-hidden-docs-96a29d70d11b
https://netbasal.com/understanding-viewchildren-contentchildren-and-querylist-in-angular-896b0c689f6e
https://netbasal.com/understanding-viewchildren-contentchildren-and-querylist-in- -angular-896b0c689f6e
Solusi lengkap salin-tempel
modal.component.html
<div
(click)="onContainerClicked($event)"
class="modal fade"
tabindex="-1"
[ngClass]="{'in': visibleAnimate}"
[ngStyle]="{'display': visible ? 'block' : 'none', 'opacity': visibleAnimate ? 1 : 0}"
*ngIf="visible">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<ng-container *ngTemplateOutlet="header"></ng-container>
<button class="close" data-dismiss="modal" type="button" aria-label="Close" (click)="close()">×</button>
</div>
<div class="modal-body">
<ng-container *ngTemplateOutlet="body"></ng-container>
</div>
<div class="modal-footer">
<ng-container *ngTemplateOutlet="footer"></ng-container>
</div>
</div>
</div>
</div>
modal.component.ts
/**
* @Stephen Paul https://stackoverflow.com/a/40144809/2013580
* @zurfyx https://stackoverflow.com/a/46949848/2013580
*/
import { Component, OnDestroy, ContentChild, TemplateRef } from '@angular/core';
@Component({
selector: 'app-modal',
templateUrl: 'modal.component.html',
styleUrls: ['modal.component.scss'],
})
export class ModalComponent implements OnDestroy {
@ContentChild('header') header: TemplateRef<any>;
@ContentChild('body') body: TemplateRef<any>;
@ContentChild('footer') footer: TemplateRef<any>;
public visible = false;
public visibleAnimate = false;
ngOnDestroy() {
// Prevent modal from not executing its closing actions if the user navigated away (for example,
// through a link).
this.close();
}
open(): void {
document.body.style.overflow = 'hidden';
this.visible = true;
setTimeout(() => this.visibleAnimate = true, 200);
}
close(): void {
document.body.style.overflow = 'auto';
this.visibleAnimate = false;
setTimeout(() => this.visible = false, 100);
}
onContainerClicked(event: MouseEvent): void {
if ((<HTMLElement>event.target).classList.contains('modal')) {
this.close();
}
}
}
modal.module.ts
import { NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';
import { ModalComponent } from './modal.component';
@NgModule({
imports: [
CommonModule,
],
exports: [ModalComponent],
declarations: [ModalComponent],
providers: [],
})
export class ModalModule { }