1. Shared CommonModuleCreate a share model: ng gm share All modules that need to be shared are exported after importing. For now, there is only CommonModule, and there will be some components that need to be shared in the future. import { NgModule } from '@angular/core'; import { CommonModule } from '@angular/common'; @NgModule({ imports: [ CommonModule ], exports: CommonModule ], declarations: [] }) export class SharedModule { } Import the core Module into the app 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 { } 2. Shared MaterialModuleFor easy management, put the import and export of Material-related components in a separate Moduel, and import and export them in ShareModule. import { NgModule } from '@angular/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, MatIconModule, MatButtonModule, MatCardModule, MatInputModule, MatListModule, MatSlideToggleModule, MatGridListModule, MatDialogModule, MatAutocompleteModule, MatMenuModule, MatCheckboxModule, MatTooltipModule, MatDatepickerModule, MatRadioModule, MatNativeDateModule, MatSelectModule ]; @NgModule({ declarations: [], imports: [ module ], exports: module ] }) export class MaterialModule { } 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, MaterialModule ], declarations: [ConfirmDialogComponent] }) export class SharedModule { } 3. Shared ConfirmDialogThe confirmation dialog box is used whether you are deleting a task or a project, so it is placed in the sharedModule. $ ng gc shared/confirm-dialog You can also create an inline template and style using ng gc shared/confirm-dialog -it -is <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)">OK</button> <button type="button" mat-button mat-dialog-close (click)="onClick(false)">Cancel</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.close(result); } } Then put the ConfirmDialogComponent component in 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, MaterialModule], declarations: [ConfirmDialogComponent], entryComponents: [ConfirmDialogComponent] }) export class SharedModule { } If you use ConfirmDialog, refer to Deleting a Project. The above is a detailed explanation of the implementation of shared modules in Angular projects. For more information about Angular, please pay attention to other related articles on 123WORDPRESS.COM! You may also be interested in:
|
<<: Summary of Nginx load balancing methods
>>: Oracle deployment tutorial in Linux environment
Linux environment variable configuration When cus...
Recently, I encountered a problem of whether the d...
Table of contents MySQL delete syntax alias probl...
question: In some browsers, such as 360 browser...
mysql download, install and configure 5.7.20 / 5....
Table of contents Usage scenarios Solution 1. Use...
We can set a background image for the cell, and w...
1. When ffmpeg pushes video files, the encoding f...
Using Technology itext.jar: Convert byte file inp...
Table of contents 1. Introduction: In this case, ...
First, let’s take an example: There is a type fie...
There are many ways to generate a global ID. Here...
Eating well and getting enough rest sounds simple...
1. Environment and preparation 1. Ubuntu 14.04 2....
In the XHTML language, we all know that the ul ta...