如何在 angular2(material2)中设置小吃店的持续时间
How can I set duration of a snack-bar in angular2 (material2)
这个例子永远留在屏幕上:
import {Component, ViewContainerRef} from '@angular/core';
import {MdSnackBar, MdSnackBarConfig} from '@angular/material';
@Component({
moduleId: module.id,
selector: 'snack-bar-demo',
templateUrl: 'snack-bar-demo.html',
})
export class SnackBarDemo {
message: string = 'Snack Bar opened.';
actionButtonLabel: string = 'Retry';
action: boolean = false;
constructor(
public snackBar: MdSnackBar,
public viewContainerRef: ViewContainerRef) { }
open() {
let config = new MdSnackBarConfig(this.viewContainerRef);
this.snackBar.open(this.message, this.action && this.actionButtonLabel, config);
}
}
如何让它在 2 秒后消失(设置 duration/timeout 某种方式)?
这应该有效
open(msg,t=2000) {
let config = new MdSnackBarConfig(this.viewContainerRef);
let simpleSnackBarRef = this.snackBar.open(msg, 'ok, gotcha', config);
setTimeout(simpleSnackBarRef.dismiss.bind(simpleSnackBarRef), t);
}
使用 angular material 2.0.0-alpha.11,您现在可以将超时添加到 snackbar。
open() {
let config = new MdSnackBarConfig();
config.duration = 10;
this.snackBar.open("Message", "Action Label", config);
}
持续时间可以通过可选配置对象传递:
this.snackBar.open(
this.message,
this.action && this.actionButtonLabel, {
duration: 2000
}
);
this._snackBar.open('Your Text','',
{
duration: 2000
});
你可以这样做 (angular 8+)
openMessageSnackBar("Server error", "OK");
openMessageSnackBar(message: string, action: string) {
this._snackBar.open(message, action, {
horizontalPosition: "center",
verticalPosition: "left",
duration: 5000,
});
}
这个例子永远留在屏幕上:
import {Component, ViewContainerRef} from '@angular/core';
import {MdSnackBar, MdSnackBarConfig} from '@angular/material';
@Component({
moduleId: module.id,
selector: 'snack-bar-demo',
templateUrl: 'snack-bar-demo.html',
})
export class SnackBarDemo {
message: string = 'Snack Bar opened.';
actionButtonLabel: string = 'Retry';
action: boolean = false;
constructor(
public snackBar: MdSnackBar,
public viewContainerRef: ViewContainerRef) { }
open() {
let config = new MdSnackBarConfig(this.viewContainerRef);
this.snackBar.open(this.message, this.action && this.actionButtonLabel, config);
}
}
如何让它在 2 秒后消失(设置 duration/timeout 某种方式)?
这应该有效
open(msg,t=2000) {
let config = new MdSnackBarConfig(this.viewContainerRef);
let simpleSnackBarRef = this.snackBar.open(msg, 'ok, gotcha', config);
setTimeout(simpleSnackBarRef.dismiss.bind(simpleSnackBarRef), t);
}
使用 angular material 2.0.0-alpha.11,您现在可以将超时添加到 snackbar。
open() {
let config = new MdSnackBarConfig();
config.duration = 10;
this.snackBar.open("Message", "Action Label", config);
}
持续时间可以通过可选配置对象传递:
this.snackBar.open(
this.message,
this.action && this.actionButtonLabel, {
duration: 2000
}
);
this._snackBar.open('Your Text','',
{
duration: 2000
});
你可以这样做 (angular 8+)
openMessageSnackBar("Server error", "OK");
openMessageSnackBar(message: string, action: string) {
this._snackBar.open(message, action, {
horizontalPosition: "center",
verticalPosition: "left",
duration: 5000,
});
}