使用完整URL做为区分页签的标识
This commit is contained in:
parent
8157327eaf
commit
588d07d1a6
|
@ -2,13 +2,13 @@
|
||||||
/** 通过URL 缓存页面
|
/** 通过URL 缓存页面
|
||||||
* 日期:2020/8/4
|
* 日期:2020/8/4
|
||||||
*/
|
*/
|
||||||
var cache = Object.create(null);
|
var cache = Object.create(null)
|
||||||
var keys = [];
|
var keys = []
|
||||||
function remove(keys, key) {
|
function remove(keys, key) {
|
||||||
if (keys && key) {
|
if (keys && key) {
|
||||||
var index = keys.indexOf(key);
|
var index = keys.indexOf(key)
|
||||||
if (index != -1) {
|
if (index !== -1) {
|
||||||
keys.splice(index, 1);
|
keys.splice(index, 1)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -16,79 +16,79 @@ function remove(keys, key) {
|
||||||
* 修剪缓存
|
* 修剪缓存
|
||||||
*/
|
*/
|
||||||
function pruneCache(keepAliveInstance, filter) {
|
function pruneCache(keepAliveInstance, filter) {
|
||||||
const { cache, keys, _vnode } = keepAliveInstance;
|
const { cache, keys, _vnode } = keepAliveInstance
|
||||||
for (const key in cache) {
|
for (const key in cache) {
|
||||||
const cachedNode = cache[key];
|
const cachedNode = cache[key]
|
||||||
if (cachedNode) {
|
if (cachedNode) {
|
||||||
if (!filter(key)) {
|
if (!filter(key)) {
|
||||||
pruneCacheEntry(cache, key, keys, _vnode);
|
pruneCacheEntry(cache, key, keys, _vnode)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
console.log("页面缓存数量:" + keys.length);
|
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
* 修剪缓存入口
|
* 修剪缓存入口
|
||||||
*/
|
*/
|
||||||
function pruneCacheEntry(cache, key, keys, current) {
|
function pruneCacheEntry(cache, key, keys, current) {
|
||||||
const cached = cache[key];
|
const cached = cache[key]
|
||||||
// 主动执行某个组件的destory,触发destroy钩子,达到销毁目的,然后移除缓存中的key-value
|
// 主动执行某个组件的destory,触发destroy钩子,达到销毁目的,然后移除缓存中的key-value
|
||||||
cached && cached.componentInstance.$destroy();
|
cached && cached.componentInstance.$destroy()
|
||||||
cache[key] = null;
|
cache[key] = null
|
||||||
remove(keys, key);
|
remove(keys, key)
|
||||||
}
|
}
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: "v-keep-alive",
|
name: 'VKeepAlive',
|
||||||
|
|
||||||
// 抽象组件
|
// 抽象组件
|
||||||
abstract: true,
|
abstract: true,
|
||||||
props: {
|
props: {
|
||||||
keyArray: []
|
keyarray: {
|
||||||
|
type: Array,
|
||||||
|
default: function() {
|
||||||
|
return []
|
||||||
|
}
|
||||||
|
}
|
||||||
},
|
},
|
||||||
created() {
|
created() {
|
||||||
// 组件创建时创建缓存对象
|
// 组件创建时创建缓存对象
|
||||||
this.cache = cache;
|
this.cache = cache
|
||||||
this.keys = keys;
|
this.keys = keys
|
||||||
},
|
},
|
||||||
|
|
||||||
destroyed() {
|
|
||||||
// 销毁时清除所有缓存
|
|
||||||
// for (const key in this.cache) {
|
|
||||||
// pruneCacheEntry(this.cache, key, this.keys);
|
|
||||||
// }
|
|
||||||
},
|
|
||||||
|
|
||||||
mounted() {
|
mounted() {
|
||||||
this.$watch("keyArray", val => {
|
this.$watch('keyarray', val => {
|
||||||
// 销毁不在key数组的对象
|
// 销毁不在key数组的对象
|
||||||
pruneCache(this, name => val.some(v => v == name));
|
pruneCache(this, name => val.some(v => v === name))
|
||||||
});
|
})
|
||||||
},
|
},
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
const slot = this.$slots.default;
|
const slot = this.$slots.default
|
||||||
const vnode = slot[0];
|
const vnode = slot[0]
|
||||||
const componentOptions = vnode && vnode.componentOptions;
|
const componentOptions = vnode && vnode.componentOptions
|
||||||
this.$vnode.componentOptions.Ctor.options.abstract = true;
|
this.$vnode.componentOptions.Ctor.options.abstract = true
|
||||||
if (componentOptions) {
|
if (componentOptions) {
|
||||||
const { cache, keys } = this;
|
const { cache, keys } = this
|
||||||
const key =
|
const key =
|
||||||
vnode.key.indexOf("__transition") == 0 ? vnode.data.key : vnode.key;
|
vnode.key.indexOf('__transition') === 0 ? vnode.data.key : vnode.key
|
||||||
|
var isCache =
|
||||||
if (cache[key]) {
|
this.keyarray.filter(v => {
|
||||||
vnode.componentInstance = cache[key].componentInstance;
|
return v === key
|
||||||
remove(keys, key);
|
}).length === 0
|
||||||
keys.push(key);
|
if (isCache) {
|
||||||
console.log("页面缓存数量:" + keys.length);
|
vnode.data.keepAlive = false
|
||||||
} else {
|
} else {
|
||||||
cache[key] = vnode;
|
if (cache[key]) {
|
||||||
keys.push(key);
|
vnode.componentInstance = cache[key].componentInstance
|
||||||
console.log("页面缓存数量:" + keys.length);
|
remove(keys, key)
|
||||||
|
keys.push(key)
|
||||||
|
} else {
|
||||||
|
cache[key] = vnode
|
||||||
|
keys.push(key)
|
||||||
}
|
}
|
||||||
vnode.data.keepAlive = true;
|
vnode.data.keepAlive = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return vnode || (slot && slot[0])
|
||||||
}
|
}
|
||||||
return vnode || (slot && slot[0]);
|
|
||||||
}
|
}
|
||||||
};
|
|
||||||
</script>
|
</script>
|
|
@ -1,7 +1,7 @@
|
||||||
<template>
|
<template>
|
||||||
<section class="app-main">
|
<section class="app-main">
|
||||||
<transition name="fade-transform" mode="out-in">
|
<transition name="fade-transform" mode="out-in">
|
||||||
<v-keep-alive :keyArray="cachedViews">
|
<v-keep-alive :keyarray="cachedViews">
|
||||||
<router-view :key="key" />
|
<router-view :key="key" />
|
||||||
</v-keep-alive>
|
</v-keep-alive>
|
||||||
</transition>
|
</transition>
|
||||||
|
@ -9,21 +9,22 @@
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import vKeepAlive from "../../components/V/v-keep-alive";
|
import vKeepAlive from '../../components/V/v-keep-alive'
|
||||||
export default {
|
export default {
|
||||||
name: "AppMain",
|
name: 'AppMain',
|
||||||
components: {
|
components: {
|
||||||
vKeepAlive
|
vKeepAlive
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
cachedViews() {
|
cachedViews() {
|
||||||
return this.$store.state.tagsView.cachedViews;
|
console.log('123', this.$store.state.tagsView.cachedViews)
|
||||||
|
return this.$store.state.tagsView.cachedViews
|
||||||
},
|
},
|
||||||
key() {
|
key() {
|
||||||
return this.$route.path;
|
return this.$route.fullPath
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style lang="scss" scoped>
|
<style lang="scss" scoped>
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
<router-link
|
<router-link
|
||||||
v-for="tag in visitedViews"
|
v-for="tag in visitedViews"
|
||||||
ref="tag"
|
ref="tag"
|
||||||
:key="tag.path"
|
:key="tag.fullPath"
|
||||||
:class="isActive(tag)?'active':''"
|
:class="isActive(tag)?'active':''"
|
||||||
:to="{ path: tag.path, query: tag.query, fullPath: tag.fullPath }"
|
:to="{ path: tag.path, query: tag.query, fullPath: tag.fullPath }"
|
||||||
tag="span"
|
tag="span"
|
||||||
|
@ -67,7 +67,7 @@ export default {
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
isActive(route) {
|
isActive(route) {
|
||||||
return route.path === this.$route.path
|
return route.fullPath === this.$route.fullPath
|
||||||
},
|
},
|
||||||
isAffix(tag) {
|
isAffix(tag) {
|
||||||
return tag.meta && tag.meta.affix
|
return tag.meta && tag.meta.affix
|
||||||
|
|
|
@ -5,7 +5,10 @@ const state = {
|
||||||
|
|
||||||
const mutations = {
|
const mutations = {
|
||||||
ADD_VISITED_VIEW: (state, view) => {
|
ADD_VISITED_VIEW: (state, view) => {
|
||||||
if (state.visitedViews.some(v => v.path === view.path)) return
|
console.log(view)
|
||||||
|
if (state.visitedViews.some(v => v.fullPath === view.fullPath)) return
|
||||||
|
console.log(3)
|
||||||
|
console.log('添加新页签')
|
||||||
state.visitedViews.push(
|
state.visitedViews.push(
|
||||||
Object.assign({}, view, {
|
Object.assign({}, view, {
|
||||||
title: view.meta.title || 'no-name'
|
title: view.meta.title || 'no-name'
|
||||||
|
@ -13,32 +16,32 @@ const mutations = {
|
||||||
)
|
)
|
||||||
},
|
},
|
||||||
ADD_CACHED_VIEW: (state, view) => {
|
ADD_CACHED_VIEW: (state, view) => {
|
||||||
if (state.cachedViews.includes(view.path)) return
|
if (state.cachedViews.includes(view.fullPath)) return
|
||||||
if (!view.meta.noCache) {
|
if (!view.meta.noCache) {
|
||||||
state.cachedViews.push(view.path)
|
state.cachedViews.push(view.fullPath)
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
DEL_VISITED_VIEW: (state, view) => {
|
DEL_VISITED_VIEW: (state, view) => {
|
||||||
for (const [i, v] of state.visitedViews.entries()) {
|
for (const [i, v] of state.visitedViews.entries()) {
|
||||||
if (v.path === view.path) {
|
if (v.fullPath === view.fullPath) {
|
||||||
state.visitedViews.splice(i, 1)
|
state.visitedViews.splice(i, 1)
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
DEL_CACHED_VIEW: (state, view) => {
|
DEL_CACHED_VIEW: (state, view) => {
|
||||||
const index = state.cachedViews.indexOf(view.path)
|
const index = state.cachedViews.indexOf(view.fullPath)
|
||||||
index > -1 && state.cachedViews.splice(index, 1)
|
index > -1 && state.cachedViews.splice(index, 1)
|
||||||
},
|
},
|
||||||
|
|
||||||
DEL_OTHERS_VISITED_VIEWS: (state, view) => {
|
DEL_OTHERS_VISITED_VIEWS: (state, view) => {
|
||||||
state.visitedViews = state.visitedViews.filter(v => {
|
state.visitedViews = state.visitedViews.filter(v => {
|
||||||
return v.meta.affix || v.path === view.path
|
return v.meta.affix || v.fullPath === view.fullPath
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
DEL_OTHERS_CACHED_VIEWS: (state, view) => {
|
DEL_OTHERS_CACHED_VIEWS: (state, view) => {
|
||||||
const index = state.cachedViews.indexOf(view.path)
|
const index = state.cachedViews.indexOf(view.fullPath)
|
||||||
if (index > -1) {
|
if (index > -1) {
|
||||||
state.cachedViews = state.cachedViews.slice(index, index + 1)
|
state.cachedViews = state.cachedViews.slice(index, index + 1)
|
||||||
} else {
|
} else {
|
||||||
|
@ -58,7 +61,7 @@ const mutations = {
|
||||||
|
|
||||||
UPDATE_VISITED_VIEW: (state, view) => {
|
UPDATE_VISITED_VIEW: (state, view) => {
|
||||||
for (let v of state.visitedViews) {
|
for (let v of state.visitedViews) {
|
||||||
if (v.path === view.path) {
|
if (v.fullPath === view.fullPath) {
|
||||||
v = Object.assign(v, view)
|
v = Object.assign(v, view)
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue