前端后台管理系统标签栏,多标签操作实现方法

页面实现效果如图:
在这里插入图片描述
代码如下:

    // 重新加载
    handleRefresh() {
      window.location.reload()
    },
    // 关闭左侧标签项
    closeLeftTags() {
      let newTags = []
      const currentIndex = this.visitedViews.findIndex(
        (i) => i === this.selectedTag
      )
      newTags = this.visitedViews.slice(currentIndex, this.visitedViews.length)
      this.$store.dispatch('tagsView/delAllViews')
      for (let i = 0; i < newTags.length; i++) {
        if (newTags[i].name || newTags[i].path) {
          this.$store.dispatch('tagsView/addView', newTags[i])
        }
      }
    },
    // 关闭右侧标签项
    closeRightTags() {
      let newTags = []
      const currentIndex = this.visitedViews.findIndex(
        (i) => i === this.selectedTag
      )
      newTags = this.visitedViews.slice(0, currentIndex + 1)
      this.$store.dispatch('tagsView/delAllViews')
      for (let i = 0; i < newTags.length; i++) {
        if (newTags[i].name || newTags[i].path) {
          this.$store.dispatch('tagsView/addView', newTags[i])
        }
      }
    },
    // 关闭当前选中项
    closeSelectedTag(view) {
      this.$store
        .dispatch('tagsView/delView', view)
        .then(({ visitedViews }) => {
          if (this.isActive(view)) {
            this.toLastView(visitedViews, view)
          }
        })
    },
    // 关闭其他标签项
    closeOthersTags() {
      this.$router.push(this.selectedTag)
      this.$store
        .dispatch('tagsView/delOthersViews', this.selectedTag)
        .then(() => {
          this.moveToCurrentTag()
        })
    },
    // 关闭全部标签项
    closeAllTags(view) {
      this.$store.dispatch('tagsView/delAllViews').then(({ visitedViews }) => {
        if (this.affixTags.some((tag) => tag.path === view.path)) {
          return
        }
        this.toLastView(visitedViews, view)
      })
    },
    toLastView(visitedViews, view) {
      const latestView = visitedViews.slice(-1)[0]
      if (latestView) {
        this.$router.push(latestView.fullPath)
      } else {
        // now the default is to redirect to the home page if there is no tags-view,
        // you can adjust it according to your needs.
        this.$router.push('/')
        this.addTags()
      }
    },
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值