我正在使用 Oracle JET 开发单页应用程序。在我正在构建的页面中,我试图在用户尝试离开页面而不保存更改时提醒他们。因此,当离开页面时,我想:
拦截路由。
检查是否有任何变化。
如果有更改,请弹出一个窗口。
如果没有任何未保存的更改,请继续路由。
我相信这应该可以使用 ojRouter (此处的文档链接),但我还没有让它工作。我已经尝试了很多方法,但这是我到目前为止的结果:
编辑:我已经更进一步并成功地访问了 canExit 属性,我在下面编辑了我的代码块。但是,这仍然不会阻止路由。
oj.Router.sync().then(() => {
const letrouterState = oj.Router.rootInstance;
letrouterState.currentState().canExit = ableToExit();
});
function ableToExit() {
let canExit;
//function that will check if the page has unsaved changes
if (ableToExit()) {
canExit = false;
} else {
canExit = true;
}
return canExit;
}
我也尝试过使用window.onhashchange. 但是,这只会在打开我的页面时触发一个事件,而不是在离开它时触发。
我希望我把我的问题说清楚了,如果需要的话,我很乐意澄清我的任何要求。有人可以帮助我吗?提前感谢您的时间。
千万里不及你
蛊毒传说
梵蒂冈之花
随时随地看视频慕课网APP
相关分类