gpt4 book ai didi

angular - 如何在 Angular 8 中正确使用 PrimeNg Toast

转载 作者:行者123 更新时间:2023-12-03 19:44:14 24 4
gpt4 key购买 nike

它正在工作,但不是应该的。而不是正确的 toast组件,消息只是在我按下提交按钮后显示为普通文本。
enter image description here

我遵循了文档中写的所有内容。这是我的文件。

包.json

"dependencies": {
...
"primeicons": "^2.0.0",
"primeng": "^8.0.3",
...
},

Angular .json
"styles": [
"src/styles.css",
"node_modules/primeicons/primeicons.css",
"node_modules/primeng/resources/themes/nova-light/theme.css",
"node_modules/primeng/resources/primeng.min.css"
],

app.module.ts
import { BrowserModule } from '@angular/platform-browser';
import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
...
import { ToastModule } from 'primeng/toast';
import { MessageService } from 'primeng/api';



@NgModule({
declarations: [
...
],
imports: [
BrowserModule,
BrowserAnimationsModule,
...
ToastModule
],
providers: [MessageService],
bootstrap: [AppComponent]
})
export class AppModule { }

贡献.component.ts
import { Component, OnInit } from '@angular/core';
...
import { MessageService } from 'primeng/components/common/api';

@Component({
selector: 'app-contribute',
templateUrl: './contribute.component.html',
styleUrls: ['./contribute.component.css']
})
export class ContributeComponent implements OnInit {
constructor(private messageService: MessageService, ...) { }

addSingle() {
this.messageService.add({severity:'success', summary:'Service Message', detail:'Via MessageService'});
}

ngOnInit() {
...
}

onSubmit() {
...
this.addSingle();
}
}

贡献.component.html
<div class="container">
<div class="row pt-5">
<div class="col-md-12 col-lg-12 col-sm-12 bg-light">
<form [formGroup]="editorForm" (ngSubmit)="onSubmit()">
<div class="form-group">
...SOME INPUT FIELDS
</div>
<p-toast position="top-left"></p-toast>
<button class="btn btn-primary mt-3 mb-3">Submit</button>
</form>
</div>
</div>
</div>

我的意思是,它的工作。不过不像好 toast零件。请纠正我。

最佳答案

在 Angular 8 中:尝试以下方法

前置步骤:

在 app.module.ts 中:

import { MessagesModule } from 'primeng/messages';
import { MessageModule } from 'primeng/message';
import { ToastModule } from 'primeng/toast';

并根据进口
    imports: [
BrowserModule,
BrowserAnimationsModule,
FormsModule,
AppRoutingModule,
MessagesModule,
MessageModule,
ToastModule,
],

第 1 步:在组件中注入(inject)消息服务供您选择,如下所示
import { MessageService } from 'primeng/api';

第 2 步:在同一个组件上,您需要添加如下提供程序
@Component({
selector: 'app-import-project',
templateUrl: './import-project.component.html',
styleUrls: ['./import-project.component.css'],
providers: [MessageService],
})

第三步:在构造函数中声明消息服务
  constructor(
private messageService: MessageService,
private router: Router,
private progress: NgProgress
) {}

第 4 步:在同一个 component.ts file: 上假设您要抛出错误消息
   showError() {
console.log('Authentication Failed');
this.messageService.add({
severity: 'error',
summary: 'Authentication Failed',
detail: 'API Key or URL is invalid.',
});
}

第 5 步:在相关的.html 文件中。添加如下 HTML 标签
<p-toast position="bottom-center"></p-toast>

输出:这肯定会抛出正确的 toast ,如下所示

希望这能解决您的问题,而不是每次都创建新项目。请试一试。

enter image description here

关于angular - 如何在 Angular 8 中正确使用 PrimeNg Toast,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57998085/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com