作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
基本上我有带有 2 个按钮的欢迎页面;登录并注册。当用户单击“注册”按钮时,会打开一个显示注册表单的模式。我实现了一个在注册时登录用户的逻辑,还有一个在他/她通过身份验证时将用户带到主页的逻辑。
这意味着当用户提交注册表并登录时,模式必须被关闭,但是仅限 主页显示后。否则,如果我在此之前关闭模式,那么用户将再次看到欢迎屏幕,我想避免这种行为。我可以在注册时轻松关闭模式,但正如我所说,我不希望用户再次看到欢迎屏幕。
这就是我在 中打开模式的方式欢迎.ts
async showModal() {
const modal = await this.modalController.create({
component: RegisterPage
});
return modal.present();
}
constructor(
private modalController: ModalController,
private router: Router
) {
this.router.events.subscribe(() => {
if (router.url.toString() === "/tabs/home" && isModalOpened) this.modalController.dismiss();
});
}
router.url.toString() === "/tabs/home"
它可以工作,但如果用户从欢迎屏幕打开模式(通过按下注册按钮)并在不提交注册表单的情况下关闭它,返回欢迎屏幕,按下登录按钮并登录,然后我会得到一个错误:
Error: Uncaught (in promise): overlay does not exist
最佳答案
您可以调用this.modalCtrl.getTop();
功能。如果未定义,则表示该组件不是通过模态 Controller 实例调用的。您可以重构代码,例如:
constructor(
private modalController: ModalController,
private router: Router
) {
this.router.events.subscribe(async () => {
const isModalOpened = await this.modalController.getTop();
if (router.url.toString() === "/tabs/home" && isModalOpened) this.modalController.dismiss();
});
}
关于angular - Ionic v4 - 检查模态是否打开,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55544477/
我来自 Asp.Net 世界,试图理解 Angular State 的含义。 什么是 Angular 状态?它类似于Asp.Net中的ascx组件吗?是子页面吗?它类似于工作流程状态吗? 我听到很多人
我一直在寻找 3 态拨动开关,但运气不佳。 基本上我需要一个具有以下状态的开关: |开 |不适用 |关 | slider 默认从中间开始,一旦用户向左或向右滑动,就无法回到N/A(未回答)状态。 有人
我是一名优秀的程序员,十分优秀!