AngularJs-destroy事件 (页面离开事件)

本文详细介绍了在AngularJS中如何使用$destroy事件来清除页面跳转后的监听事件,避免了因未清理监听导致的内存泄漏问题。通过实例展示了在Controller中监听$destroy事件,确保在页面跳转后能够正确地清理当前页面的监听器,如window.scroll事件,防止在下一页scroll时继续触发。同时,文章还提供了一个示例,演示了如何在$destroy事件的回调中检查必填信息是否完整。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    $scope.$on("$destroy", function() {
            //清除配置,不然scroll会重复请求
        })

在Controller中监听$destory事件,这个事件会在页面发生跳转的时候触发。

在页面跳转之后,这个页面监听的一些全局事件,比如window.scroll事件在下一页scroll的时候还会继续被触发

在这个事件的回调中,清除当前页面的监听或者一些参数保证下面的页面不会再触发当前页面的事件回调.

controller:'UserInfo'
//验证必填信息
$scope.$on("$destroy", function() {
   if(!$scope.currentUser.telephone || !$scope.currentUser.address){
      layer.alert("请将个人信息补充完整");
      $location.path("userInfo");
   }
})

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值