1. 程式人生 > 程式設計 >詳解Angular專案中共享模組的實現

詳解Angular專案中共享模組的實現

一、共享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的資料請關注我們其它相關文章!