[转]Angular 4|5 Material Dialog with Example
本文转自:https://www.techiediaries.com/angular-material-dialogs/
We'll also see common cases to work with the Angular Material Dialog such as:
- how to create a dialog,
- how to pass data to the dialog component,
- how to get data back from a dialog component,
- how to use various configuration options for dialogs.
Before starting, first, you’ll need to make sure you have followed the steps to setup Angular Material for your Angular application.
Most Angular Material components have their own module so you can use a specific component without importing the whole library. For Dialog you need to import the MatDialogModule module:
import {MatDialogModule} from "@angular/material";
Next you need to add the module to your main module imports array.
/* ... */
@NgModule({
declarations: [AppComponent],
imports: [BrowserModule, MatDialogModule],
providers: [],
bootstrap: [AppComponent]
})
export class AppModule {}
Now you are ready to create your dialog. The process involves a few steps:
- first, you need to import and inject
MatDialogin the component constructor where you want to call the dialog, - next, you need to create an instance of
MatDialogConfigwhich holds configuration options for the dialog (this is optional, you can also pass a literal object i.e{...}), - finally you need to call the
open()method of the injectedMatDialoginstance with the component to use as the body of the dialog and the configuration object.
From the final step, you can understand that the open() method needs a component as a body so you'll need to create an Angular component.
Use the Angular CLI to generate a component:
ng g component dialog-body
Next, you’ll need to import the dialog component in the app module and add it into the declarations and entryComponents arrays:
import { BrowserModule } from "@angular/platform-browser";
import { NgModule } from "@angular/core";
import { MatDialogModule } from "@angular/material";
import { AppComponent } from "./app.component";
import { DialogBodyComponent } from "./dialog-body/dialog-body";
@NgModule({
declarations: [AppComponent, DialogBodyComponent],
imports: [BrowserModule, MatDialogModule],
providers: [],
bootstrap: [AppComponent],
entryComponents: [DialogBodyComponent]
})
export class AppModule {}
Step 1: Importing and Injecting MatDialog
To be able to call the dialog, you'll need to import and inject MatDialog in the calling component i.e for this example AppComponent:
import { Component, Inject } from "@angular/core";
import {
MatDialog,
MatDialogConfig
} from "@angular/material";
@Component({
selector: "app-root",
templateUrl: "./app.component.html",
styleUrls: ["./app.component.css"]
})
export class AppComponent {
title = "Example Angular Material Dialog";
constructor(private dialog: MatDialog) {}
}
Step 2: Opening the Dialog
Next add the openDialog() method which opens the dialog:
openDialog() {
const dialogConfig = new MatDialogConfig();
this.dialog.open(DialogBodyComponent, dialogConfig);
}
As we already said, you open the dialog by calling the open() method of the injected MdDialog instance and you pass the dialog component as a parameter and an optional configuration object.
You can pass different configuration option such as:
- data: object or string to send data to the dialog,
- height: set the height of the dialog,
- width: set the width of the dialog,
- disableClose: enable/disable closing the form by clicking outside the dialog,
- autoFocus: if true, automatically sets focus on the first form field etc.
Step 3: Creating the Dialog Component
We have previously generated the dialog body component. Now let's use Angular Material directives designed to style the dialog body:
mat-dialog-title: This directive is used for the title of the dialog,mat-dialog-content: this directive is designed for the container of body of this dialog,mat-dialog-actions: this directive is designed for the container of the action buttons at the bottom of the dialog
Open src/dialog-body/dialog-body.htmland add:
<h2 mat-dialog-title>This is a Dialog title</h2>
<mat-dialog-content>
<p> Place content here </p>
</mat-dialog-content>
<mat-dialog-actions>
<button class="mat-raised-button" (click)="close()">Close</button>
</mat-dialog-actions>
Step 4: Closing the Dialog and Implementing Action Buttons
The MatDialogRef provides a reference of the opened dialog. This reference can be used to close the dialog and also to notify the calling component when the dialog gets closed. Any component created via MatDialog can inject the MatDialogRef reference and use it to perform the previously mentionned operations.
Now let's implement the close button. First import MatDialogRef from @angular/material:
import { MatDialogRef } from "@angular/material";
Next inject MatDialogRef<DialogBodyComponent> as dialogRef.
@Component({
selector: "dialog-b",
template: "<h1>Dialog body component</h1>"
})
export class DialogBodyComponent {
constructor(
public dialogRef: MatDialogRef<DialogBodyComponent>){}
Finally, you can use this reference to the dialog component to control many aspects such as closing the dialog and sending data back to the parent component etc.
close() {
this.dialogRef.close();
}
You can optionally pass some value which can be received back in the calling component.
close() {
this.dialogRef.close("Thanks for using me!");
}
Step 5: Sending Data to The Dialog Component
To be able to send or more accurately share data with the dialog component, you can use the data option to pass data:
openDialog() {
const dialogConfig = new MatDialogConfig();
dialogConfig.data = "some data";
let dialogRef = this.dialog.open(DialogBodyComponent, dialogConfig);
}
You can also pass objects instead of simple string values:
dialogConfig.data = { name: "some name"};
For accessing shared data in your dialog component, you need to use the MAT_DIALOG_DATAinjection token:
import { Component, Inject } from "@angular/core";
import {
MAT_DIALOG_DATA
} from "@angular/material";
@Component({
selector: "dialog-b",
template: "passed in data: "
})
export class DialogBodyComponent {
constructor(@Inject(MAT_DIALOG_DATA) public data: any) {}
}
Step 6: Receiving Data from The Dialog Component
In the calling component, we can get the data passed from the dialog. From the previous example, you can see that calling the open() method returns a reference to the dialog:
let dialogRef = this.dialog.open(DialogBodyComponent, dialogConfig);
This dialog reference has a afterClosed() observable which can be subscribed to. The data passed from the dialog is emitted from this observable.
dialogRef.afterClosed().subscribe(value => {
console.log(`Dialog sent: ${vaue}`);
});
Conclusion
Dialogs represents an important UI component for most web application and thanks to Angular Material you can quickly craft professional and good looking dialogs without having to deal with CSS.
10 Apr 2018
[转]Angular 4|5 Material Dialog with Example的更多相关文章
- [转]Angular4 引用 material dialog时自定义对话框/deep/.mat-dialog-container
本文转自:https://blog.csdn.net/qq_24078843/article/details/78560556 版权声明:本文为博主原创文章,未经博主允许不得转载. https://b ...
- 【转】Android新组件Material Dialog,SwipeRefreshLayout,ListPopupWindow,PopupMenu等
朝花夕拾----新组件的学习和使用 分类: Android UI2015-06-26 11:31 440人阅读 评论(0) 收藏 举报 uidialogMaterial 目录(?)[-] Mate ...
- angular material dialog应用
1. 打开弹窗的点击事件 project.component.html <button mat-icon-button class="action-button" (clic ...
- 拟物设计和Angular的实现 - Material Design(持续更新)
Material Design是Google最新发布的跨平台统一视觉设计语言.直接翻译是物质设计,但是我更倾向于使用"拟物设计"更为准确. 据谷歌介绍,Material Desig ...
- Angular 学习笔记 (Material Datepicker)
https://material.angular.io/components/datepicker/overview 官网介绍很清楚了,这里记入一下我比较不熟悉的. 1. moment js Angu ...
- Angular 学习笔记 Material
以后都不会写 0 到 1 的学习记入了,因为官网已经写得很好了. 这里只写一些遇到的坑或则概念和需要注意的事情. Material Table 1. ng-content 无法传递 CdkColumn ...
- 拟物设计和Angular的实现 - Material Design
Material Design是Google最新发布的跨平台统一视觉设计语言.直接翻译是物质设计,但是我更倾向于使用"拟物设计"更为准确. 据谷歌介绍,Material Desig ...
- Angular 学习笔记 (Material Select and AutoComplete)
记入一些思考 : 这 2 个组件有点像,经常会搞混. select 的定位是选择. 目前 select 最糟糕的一点是 not search friendly. 还有当需要 multiple sele ...
- Angular 学习笔记 (Material table sticky 原理)
更新 : 2019-12-03 今天踩坑了, sticky 了解不够深 refer http://www.ruanyifeng.com/blog/2019/11/css-position.html 阮 ...
随机推荐
- ibatis (六) dynamic的用法
view plain copy print? dynamic可以去除第一个prepend="and"中的字符(这里为and),从而可以帮助你实现一些很实用的功能.具体情况如下: 1 ...
- (PMP)第6章-----项目进度管理
6.1 规划进度管理 输入 工具与技术 输出 1.项目章程 2.项目管理计划 (范围管理计划, 开发方法) 3.事业环境因素 4.组织过程资产 1.专家判断 2.数据分析 3.会议 1.进度管理计划 ...
- python之路(六)-函数相关
在没有学习函数之前我们的程序是面向过程的,不停的判断,不停的循环,同样的代码重复出现在我们的代码里.函数可以更好的提高我们的 代码质量,避免同样的代码重复出现,而只需要在用的时候调用函数即可执行.此为 ...
- JVM--关于MinGC,FullGC
一.Minor GC 发生在新生代上,因为新生代对象存活时间很短,因此 Minor GC 会频繁执行,执行的速度一般也会比较快,通过幸存区交换来处理 1.触发条件: 当创建对象时Eden区空间不够时触 ...
- Servlet的补充知识
ServletContextAware是获取ServletContext一个接口.只需要实现此接口重写里面的setServletContext方法,spring在初始化的时候通过xmlClasspat ...
- Jenkins内置环境变量的使用
一.查看Jenkins有哪些环境变量 1.新建任意一个job 2.增加构建步骤:Execute shell 或 Execute Windows batch command 3.点击输入框下方的“可用环 ...
- HYSBZ2565最长双回文串 Manacher
顺序和逆序读起来完全一样的串叫做回文串.比如 acbca 是回文串,而 abc 不是( abc 的顺序为 “abc” ,逆序为 “cba” ,不相同). 输入长度为 n 的串 S ,求 S 的最长双回 ...
- JavaScript实现HTML页面集成QQ空间分享功能
<!DOCTYPE HTML> <html> <head> <title>QQ空间分享</title> <meta http-equi ...
- 第九节:详细讲解Java中的泛型,多线程,网络编程
前言 大家好,给大家带来详细讲解Java中的泛型,多线程,网络编程的概述,希望你们喜欢 泛型 泛型格式:ArrayList list= new ArrayList(); ArrayList list= ...
- 《机器学习实战(基于scikit-learn和TensorFlow)》第四章内容的学习心得
本章主要讲训练模型的方法. 线性回归模型 闭式方程:直接计算最适合训练集的模型参数 梯度下降:逐渐调整模型参数直到训练集上的成本函数调至最低,最终趋同与第一种方法计算出的参数 首先,给出线性回归模型的 ...