angular.js - 单页应用(ng/vue)该如何监听用户离开当前页面(或者路由)?
问题描述
场景描述:在ng的某个路由中,需要在用户离开当前路由时提示用户是否确认离开
我的疑惑:如果是普通的应用,我们可以使用js来判断用户是否要离开,但是在单页应用中,所有的跳转离开其实都是在一个页面中,我想判断用户是否离开当前路由,但是没找到ng提供的公户离开路由的方法
求各位前辈的思路~
问题解答
回答1:我只知道Vue可以
route: { deactivate() {... }}回答2:
ui-router里面有一个事件可以监控状态的改变,回调函数中参数可以记录当前页面$rootScope.$on(’$stateChangeStart’, function (event, toState, fromState){});
回答3:ng中如果使用ui-router来作为路由系统。可以使用ui-router的事件系统来对路由状态的变化做出相应的业务逻辑。
$rootScope.$on(’$stateChangeStart’,function(event, toState, toParams, fromState, fromParams){ event.preventDefault(); // transitionTo() promise will be rejected with // a ’transition prevented’ error})
详情可以参考ui-router中的$state
回答4:js原生通过hashchange事件,来监听页面hash是否变化,在单页面应用中,很多的框架都会封装这个方法成钩子函数。
相关文章:
1. thinkphp6中怎么把类放到容器中?2. vue.js - 为什么我的vue项目上传到github不能预览?3. 怎么学好php4. javascript - 呈现引擎是什么?5. javascript - Ajax加载Json时,移动端页面向左上角缩小一截儿,加载完成后才正常显示,这该如何解决?6. javascript - vue webpack打包问题7. mysql - 把一个表中的数据count更新到另一个表里?8. javascript - jquery怎么给select option一个点击时触发的事件,如图 如果选择自定义触发一个时间?9. 如何更新/删除指定的两条或多条数据10. 闯关的第二个问题的答案是错的吧?

网公网安备