自己维护vue项目的路由跳转历史记录
问题:公司开发一个商城,总是遇到回退到上页面时会有很多逻辑处理,由于每个页面都要写回退的方法,所以总会漏掉一些判断,导致出现很多类似的bug。
解决方法:
方案一:使用vue-router的history堆栈,待学习。。。
方案二:想到了可能自己封装一下,来维护路由页面跳转应该会更方便一些。
所以开始吧!
方案二实现:↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓
暂时还没有时间在项目中实践,只是从别人那记录学习一下,以便之后使用。待更新。。。。
学习地址:https://www.cnblogs.com/dora-zc/p/10888071.html
实现一个Vue小插件:
- 新建文件src/utils/routerhistory.js,通过堆栈的方式维护页面跳转的历史记录,控制返回跳转。
- 点击返回按钮是出栈操作。
- 在全局路由router.js中,实例化路由前,通过原型扩展router的back的方法。
- 在全局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>