• vue 阻止页面跳转 , 询问是否离开页面 , 确定后离开, 禁用浏览器返回功能


    项目中遇到如下需求

    1. 数据录入页面 , 用户没有保存数据的时候, 发生路由跳转, 浏览器返回 时加以阻止 , 并给出提示 , 询问未保存, 是否离开页面
    2. 点击保存以后 , 可以返回 , 自动跳转 , 进入下一个页面不加限制

    实现过程 : 两个方面入手 , 

    1. 浏览器返回功能 , 需要处理,
    2. vue-router 需要处理

    实现方法(两者结合)

    浏览器返回处理方式

    // mounted()的时候我们调用原生js , 操作一下history

    history.pushState(null, null, document.URL); // 主要是在不刷新浏览器的情况下,创建新的浏览记录并插入浏览记录队列中。 这步非常重要 , 不然的话当我们点击返回按钮 , 虽然页面阻止了跳转 , 但是url地址栏却发生了变化 window.onpopstate = function (event) { // alert("location: " + document.location + ", state: " + JSON.stringify(event.state)); history.pushState(null, null, document.URL);
    //使用element that .$confirm("离开页面 , bom将不做保存, 请确认已经保存", "提示", { confirmButtonText: "确定", cancelButtonText: "取消", type: "warning", }) .then(() => { that.deleteFile();//业务功能 , 可以忽略 that.$router.push({ name: "跳转到页面的name", params: { status: true } });//此处手动增加了状态 , 主要为了监听路由跳转的时候判断是否进行跳转 , 看下面代码 }) .catch(() => { // alert("window") return false; }); };

      vue-router的处理方式

    // vue路由的钩子函数 , 可以放在mouted的同级
    beforeRouteLeave(to, from, next) { console.log(to); console.log(from); if (to.params.status) {//就是上面的状态 如果是true , 则不询问是否保存, 当然这个方法比较笨, 大家可以使用更优雅的方式 next(); } else { this.$confirm("离开页面 , bom将不做保存, 请确认已经保存", "提示", { confirmButtonText: "确定", cancelButtonText: "取消", type: "warning", }) .then(() => { this.deleteFile();//业务功能请忽略 next(); }) .catch(() => { // alert("router") }); } },

    基本上就实现了 , 没有经过测试 , 具体的bug以后有问题再修改吧

  • 相关阅读:
    Linux/UNIX编程:实现简单 tee 命令
    Java原子变量类需要注意的问题
    一种很有意思的数据结构:Bitmap
    Java实现简单井字棋
    分治算法学习
    使用栈实现表达式求值
    Web安全学习笔记——SQL注入
    【old】Python学习笔记
    函数1
    pycharm(Tip of Day)
  • 原文地址:https://www.cnblogs.com/sunjinggege/p/14363332.html
Copyright © 2020-2023  润新知