自己维护vue项目的路由跳转历史记录

问题:公司开发一个商城,总是遇到回退到上页面时会有很多逻辑处理,由于每个页面都要写回退的方法,所以总会漏掉一些判断,导致出现很多类似的bug。

解决方法:

方案一:使用vue-router的history堆栈,待学习。。。

方案二:想到了可能自己封装一下,来维护路由页面跳转应该会更方便一些。

所以开始吧!

 

方案二实现:↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓

暂时还没有时间在项目中实践,只是从别人那记录学习一下,以便之后使用。待更新。。。。

学习地址:https://www.cnblogs.com/dora-zc/p/10888071.html


实现一个Vue小插件:

  1. 新建文件src/utils/routerhistory.js,通过堆栈的方式维护页面跳转的历史记录,控制返回跳转。
  2. 点击返回按钮是出栈操作。
  3. 在全局路由router.js中,实例化路由前,通过原型扩展router的back的方法。
  4. 在全局afterEach中存放历史记录。

新建页面

// src/utils/routerhistory.js
 
const History = {
    _history: [], // 历史记录堆栈
    install(Vue) {
        // 提供Vue插件所需安装方法
        Object.defineProperty(Vue.prototype, '$routerHistory', {
            get() {
                return History;
            }
        })
    },
    push(path) { // 入栈
        this._history.push(path);
    },
    pop() {
        this._history.pop();
    },
    canBack(){
        return this._history.length > 1;
    }
 
}
export default History;

在路由实例化之前,扩展back()方法

// src/router.js
 
import Vue from 'vue'
import Router from 'vue-router'
import History from './utils/history';
 
Vue.use(Router);
Vue.use(History);
 
// 实例化之前,扩展Router
Router.prototype.goBack = function () {
  this.isBack = true;
  this.back();
}

 在路由全局afterEach中记录跳转历史

// src/router.js
 
// afterEach记录历史记录
router.afterEach((to, from) => {
  if (router.isBack) {
    // 后退
    History.pop();
    router.isBack = false;
    router.transitionName = 'route-back';
  } else {
    History.push(to.path);
    router.transitionName = 'route-forward';
  }
})

在公用Header组件中使用

// Hearder.vue
 
<template>
  <div class="header">
    <h1>{{title}}</h1>
    <i v-if="$routerHistory.canBack()" @click="back"></i>
    <div class="extend">
      <slot></slot>
    </div>
  </div>
</template>
 
<script>
export default {
  props: {
    title: {
      type: String,
      default: ""
    }
  },
  methods: {
    back() {
      this.$router.goBack();
    }
  }
};
</script>

 

posted @ 2022-12-01 10:44  小那  阅读(1299)  评论(0编辑  收藏  举报