Ionic 4 Angular: Uncaught ReferenceError: dismissModal is not defined at HTMLElement.onclick (BUT function IS defined!)
Ionic 4 Angular: Uncaught ReferenceError: dismissModal is not defined at HTMLElement.onclick (BUT function IS defined!)
Error:
Uncaught ReferenceError: dismissModal is not defined
at HTMLElement.onclick
比赛-总结-Modal.component.html
<ion-header translucent>
<ion-toolbar>
<ion-title>Match Summary</ion-title>
<ion-buttons slot="end">
<ion-button onclick="dismissModal()">Return to Queue Page</ion-button>
</ion-buttons>
</ion-toolbar>
</ion-header>
<ion-content>
<ion-card>
<ion-card-content>This match you had a score of {{score}}</ion-card-content>
<ion-card-content>And a place of {{place}} out of {{playerCount}} players</ion-card-content>
</ion-card>
</ion-content>
比赛-总结-Modal.component.ts
import { Component, OnInit, Input} from '@angular/core';
import { ModalController } from '@ionic/angular';
@Component({
selector: 'app-match-summary-modal',
templateUrl: './match-summary-modal.component.html',
styleUrls: ['./match-summary-modal.component.scss'],
})
export class MatchSummaryModalComponent implements OnInit {
@Input() score: number;
@Input() place: number;
@Input() playerCount: number;
constructor(private modalController: ModalController) {
}
ngOnInit() {}
async dismissModal() {
this.modalController.dismiss()
}
}
GameNetworkService.ts
(在服务中的某处,注入了 modalController)
this.lobbyServerSocket.on('match-summary', async (summarydata) => {
let modal = await this.modalController.create({
component: MatchSummaryModalComponent,
componentProps: {
score: summarydata.score,
place: summarydata.place,
playerCount: summarydata.playerCount
}
})
await modal.present()
this.lobbyServerSocket.disconnect(true)
this.lobbyServerSocket = null;
})
问题
当 dismissModal()
在 MatchSummaryModal 中明确定义时,
为什么 angular/ionic 无法找到 dismissModal()
方法,该方法在单击按钮时被清楚地调用并包含在组件中?
此外,我需要做什么才能获得预期的功能? (这是为了让模态在点击按钮时自行消失)
谢谢!
应该是
<ion-button (click)="dismissModal()">Return to Queue Page</ion-button>
而不是
<ion-button onclick="dismissModal()">Return to Queue Page</ion-button>
Error: Uncaught ReferenceError: dismissModal is not defined at HTMLElement.onclick
比赛-总结-Modal.component.html
<ion-header translucent>
<ion-toolbar>
<ion-title>Match Summary</ion-title>
<ion-buttons slot="end">
<ion-button onclick="dismissModal()">Return to Queue Page</ion-button>
</ion-buttons>
</ion-toolbar>
</ion-header>
<ion-content>
<ion-card>
<ion-card-content>This match you had a score of {{score}}</ion-card-content>
<ion-card-content>And a place of {{place}} out of {{playerCount}} players</ion-card-content>
</ion-card>
</ion-content>
比赛-总结-Modal.component.ts
import { Component, OnInit, Input} from '@angular/core';
import { ModalController } from '@ionic/angular';
@Component({
selector: 'app-match-summary-modal',
templateUrl: './match-summary-modal.component.html',
styleUrls: ['./match-summary-modal.component.scss'],
})
export class MatchSummaryModalComponent implements OnInit {
@Input() score: number;
@Input() place: number;
@Input() playerCount: number;
constructor(private modalController: ModalController) {
}
ngOnInit() {}
async dismissModal() {
this.modalController.dismiss()
}
}
GameNetworkService.ts (在服务中的某处,注入了 modalController)
this.lobbyServerSocket.on('match-summary', async (summarydata) => {
let modal = await this.modalController.create({
component: MatchSummaryModalComponent,
componentProps: {
score: summarydata.score,
place: summarydata.place,
playerCount: summarydata.playerCount
}
})
await modal.present()
this.lobbyServerSocket.disconnect(true)
this.lobbyServerSocket = null;
})
问题
当 dismissModal()
在 MatchSummaryModal 中明确定义时,
为什么 angular/ionic 无法找到 dismissModal()
方法,该方法在单击按钮时被清楚地调用并包含在组件中?
此外,我需要做什么才能获得预期的功能? (这是为了让模态在点击按钮时自行消失)
谢谢!
应该是
<ion-button (click)="dismissModal()">Return to Queue Page</ion-button>
而不是
<ion-button onclick="dismissModal()">Return to Queue Page</ion-button>