|
|
|
@ -21,6 +21,7 @@
|
|
|
|
|
<li @click="refreshSelectedTag(selectedTag)">刷新页面</li>
|
|
|
|
|
<li v-if="!isAffix(selectedTag)" @click="closeSelectedTag(selectedTag)">关闭当前</li>
|
|
|
|
|
<li @click="closeOthersTags">关闭其他</li>
|
|
|
|
|
<li v-if="!isLastView()" @click="closeRightTags">关闭右侧</li>
|
|
|
|
|
<li @click="closeAllTags(selectedTag)">关闭所有</li>
|
|
|
|
|
</ul>
|
|
|
|
|
</div>
|
|
|
|
@ -83,6 +84,13 @@ export default {
|
|
|
|
|
isAffix(tag) {
|
|
|
|
|
return tag.meta && tag.meta.affix
|
|
|
|
|
},
|
|
|
|
|
isLastView() {
|
|
|
|
|
try {
|
|
|
|
|
return this.selectedTag.fullPath === this.visitedViews[this.visitedViews.length - 1].fullPath
|
|
|
|
|
} catch (err) {
|
|
|
|
|
return false
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
filterAffixTags(routes, basePath = '/') {
|
|
|
|
|
let tags = []
|
|
|
|
|
routes.forEach(route => {
|
|
|
|
@ -152,6 +160,13 @@ export default {
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
},
|
|
|
|
|
closeRightTags() {
|
|
|
|
|
this.$store.dispatch('tagsView/delRightTags', this.selectedTag).then(visitedViews => {
|
|
|
|
|
if (!visitedViews.find(i => i.fullPath === this.$route.fullPath)) {
|
|
|
|
|
this.toLastView(visitedViews)
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
},
|
|
|
|
|
closeOthersTags() {
|
|
|
|
|
this.$router.push(this.selectedTag).catch(()=>{});
|
|
|
|
|
this.$store.dispatch('tagsView/delOthersViews', this.selectedTag).then(() => {
|
|
|
|
|