詳解Angular專案中共享模組的實現
阿新 • • 發佈:2021-05-25
一、共享CommonModule
建立share Modele:ng g m share
import進來所有需要共享的模組都export出去,
暫時只有CommonModule,以後會有一些需要共享的元件。
import { NgModule } from '@angular/core'; import { CommonModule } from '@angular/common'; @NgModule({ imports: [ CommonModule ],exports:[ CommonModule ],declarations: kNGqThEVn[] }) export class SharedModule { }
在app Module中把core Module匯入進來。
import { BrowserModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; import { AppComponent } from './app.component'; import {CoreModule} from './core/core.module'; @NgModule({ declarations: [ AppComponent ],imports: [ BrowserModule,CoreModule ],providers: [],bootstrap: [AppComponent] }) export class AppModule { }
二、共享MaterialModule
為了方便管理,把Material相關元件的匯入匯出單獨放在一個Moduel中,在ShareModule中匯入匯出即可。
import { NgModule } from '@ang程式設計客棧ular/core'; import { CommonModule } from '@angular/common'; import { MatToolbarModule,MatSidenavModule,MatButtonModule,MatCardModule,MatInputModule,MatListModule,MatSlideToggleModule,MatGridListModule,MatDialogModule,MatAutocompleteModule,MatMenuModule,MatCheckboxModule,MatTooltipModule,MatDatepickerModule,MatRadioModule,MatNativeDateModule,MatSelectModule } from '@angular/material'; import { MatIconModule } from '@angular/material'; const module=[ MatSidenavModule,MatIconModule,MatToolbarModule,MatSelectModule ]; @NgModule({ declarations: [],imports: [ module ],exports:[ module ] }) export class MaterialModule { }
import { www.cppcns.comNgModule } from '@angular/core'; import { CommonModule } from '@angular/common'; import { MaterialModule } from '../material/material.module'; import { ConfirmDialogComponent } from './confirm-dialog/confirm-dialog.component'; @NgModule({ imports: [ CommonModule,MaterialModule ],exports:[ CommonModule,declarations: [ConfirmDialogComponent] }) export class SharedModule { }
三、共享ConfirmDialog
確認對話方塊不管是在刪除任務還是在刪除專案中都會用到,所以放在sharedModule中。
$ ng g c shared/confirm-dialog
也可以通過ng g c shared/confirm-dialog -it -is建一個內聯的template和style
<form> <h2 md-dialog-title>{{title}}</h2> <div mat-dialog-content> {{content}} </div> <div mat-dialog-actions> <button type="button" mat-raised-button color="primary" (click)="onClick(true)">確定</button> <button type="button" mat-button 程式設計客棧mat-dialog-close (click)="onClick(false)">取消</button> </div> </form>
import { Component,OnInit,Inject } from "@angular/core"; import { MatDialogRef } from "@angular/material"; import { MAT_DIALOG_DATA } from "@angular/material"; @Component({ selector: "app-confirm-dialog",templateUrl: "./confirm-dialog.component.html",styleUrls: ["./confirm-dialog.component.scss"] }) export class ConfirmDialogComponent implements OnInit { title = ""; content = ""; constructor( private dialogRef: MatDialogRef<ConfirmDialogComponent>,@Inject(MAT_DIALOG_DATA) private data ) { } ngOnInit() { this.title = this.data.title; this.content = this.data.content; } onClick(result: boolean) { this.dialogRef.closekNGqThEVn(result); } }
然後把ConfirmDialogComponent元件放在sharedModule中。
import { NgModule } from "@angular/core"; import { CommonModule } from "@angular/common"; import { MaterialModule } from "../material/material.module"; import { ConfirmDialogComponent } from "./confirm-dialog/confirm-dialog.component"; @NgModule({ imports: [CommonModule,MaterialModule],exports: [CommonModule,declarations: [ConfirmDialogComponent],entryComponents: [ConfirmDialogComponent] }) export class SharedModule { }
如果使用ConfirmDialog,可參考刪除project。
以上就是詳解Angular專案中共享模組的實現的詳細內容,更多關於Angular的資料請關注我們其它相關文章!