码迷,mamicode.com
首页 > 其他好文 > 详细

vue 添加移除beforeunload事件

时间:2018-08-29 14:17:20      阅读:1201      评论:0      收藏:0      [点我收藏+]

标签:move   方法   阻塞   用户权限   handler   window   无法   ble   权限   

 var vue = new Vue({
        el: ‘#app‘,
        methods: {
            //添加beforeunload监听事件
            createBeforeunloadHandler() {
                //window.addEventListener(‘beforeunload‘, e => this.beforeunloadHandler(e));
                window.addEventListener(‘beforeunload‘, this.beforeunloadHandler, false);
            },
            //移除beforeunload事件
            destroyedBeforeunloadHandler() {
                //window.removeEventListener(‘beforeunload‘, e => this.beforeunloadHandler(e));//错误方法,无法移除
                window.removeEventListener(‘beforeunload‘, this.beforeunloadHandler, false);
                //this.rowEditEnable = 0;
            },
            //beforeunload监听事件
            beforeunloadHandler(e) {
                    e.returnValue = "确定要关闭窗口吗?";
                    console.log("释放权限操作");
                    //释放权限操作,无阻塞
                    //用户点击取消后执行,恢复操作
                    setTimeout(function () {
                        setTimeout(function () {
                 console.log("恢复用户权限操作");
              }, 50) }, 50); }, }, beforeDestroy() { //在 beforeDestroy 钩子移除beforeunload事件 this.destroyedBeforeunloadHandler(); }, });

 

vue 添加移除beforeunload事件

标签:move   方法   阻塞   用户权限   handler   window   无法   ble   权限   

原文地址:https://www.cnblogs.com/bearwcn/p/9553145.html

(0)
(1)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!