diff --git a/src/components/cache/AKeepAlive.js b/src/components/cache/AKeepAlive.js index 23f0031..b04660a 100644 --- a/src/components/cache/AKeepAlive.js +++ b/src/components/cache/AKeepAlive.js @@ -4,7 +4,16 @@ const patternTypes = [String, RegExp, Array] function matches (pattern, name) { if (Array.isArray(pattern)) { - return pattern.indexOf(name) > -1 + if (pattern.indexOf(name) > -1) { + return true + } else { + for (let item of pattern) { + if (isRegExp(item) && item.test(name)) { + return true + } + } + return false + } } else if (typeof pattern === 'string') { return pattern.split(',').indexOf(name) > -1 } else if (isRegExp(pattern)) { @@ -18,6 +27,13 @@ function getComponentName (opts) { return opts && (opts.Ctor.options.name || opts.tag) } +function getComponentKey (vnode) { + const {componentOptions, key} = vnode + return key == null + ? componentOptions.Ctor.cid + (componentOptions.tag ? `::${componentOptions.tag}` : '') + : key + componentOptions.Ctor.cid +} + function getFirstComponentChild (children) { if (Array.isArray(children)) { for (let i = 0; i < children.length; i++) { @@ -35,7 +51,8 @@ function pruneCache (keepAliveInstance, filter) { const cachedNode = cache[key] if (cachedNode) { const name = getComponentName(cachedNode.componentOptions) - if (name && !filter(name)) { + const componentKey = getComponentKey(cachedNode) + if (name && !filter(name, componentKey)) { pruneCacheEntry(cache, key, keys, _vnode) } } @@ -70,6 +87,7 @@ export default { props: { include: patternTypes, exclude: patternTypes, + excludeKeys: patternTypes, max: [String, Number], clearCaches: Array }, @@ -98,10 +116,13 @@ export default { mounted () { this.$watch('include', val => { - pruneCache(this, name => matches(val, name)) + pruneCache(this, (name) => matches(val, name)) }) this.$watch('exclude', val => { - pruneCache(this, name => !matches(val, name)) + pruneCache(this, (name) => !matches(val, name)) + }) + this.$watch('excludeKeys', val => { + pruneCache(this, (name, key) => !matches(val, key)) }) }, @@ -112,12 +133,14 @@ export default { if (componentOptions) { // check pattern const name = getComponentName(componentOptions) - const { include, exclude } = this + const componentKey = getComponentKey(vnode) + const { include, exclude, excludeKeys } = this if ( // not included (include && (!name || !matches(include, name))) || // excluded - (exclude && name && matches(exclude, name)) + (exclude && name && matches(exclude, name)) || + (excludeKeys && componentKey && matches(excludeKeys, componentKey)) ) { return vnode } diff --git a/src/config/default/setting.config.js b/src/config/default/setting.config.js index 77dd171..19e736a 100644 --- a/src/config/default/setting.config.js +++ b/src/config/default/setting.config.js @@ -15,6 +15,7 @@ module.exports = { pageWidth: 'fixed', //内容区域宽度,fixed:固定宽度,fluid:流式宽度 weekMode: false, //色弱模式,true:开启,false:不开启 multiPage: false, //多页签模式,true:开启,false:不开启 + cachePage: true, //是否缓存页面数据,仅多页签模式下生效,true 缓存, false 不缓存 hideSetting: false, //隐藏设置抽屉,true:隐藏,false:不隐藏 systemName: 'Vue Antd Admin', //系统名称 copyright: '2018 ICZER 工作室出品', //copyright diff --git a/src/layouts/tabs/TabsView.vue b/src/layouts/tabs/TabsView.vue index 46d0430..beb8ae7 100644 --- a/src/layouts/tabs/TabsView.vue +++ b/src/layouts/tabs/TabsView.vue @@ -12,10 +12,10 @@ />