使用完整URL做为区分页签的标识

This commit is contained in:
张巍 2020-08-05 12:00:02 +08:00
parent 8157327eaf
commit 588d07d1a6
4 changed files with 72 additions and 68 deletions

View File

@ -1,14 +1,14 @@
<script> <script>
/**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]
// destorydestroykey-value // destorydestroykey-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>

View File

@ -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>

View File

@ -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

View File

@ -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
} }