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

前端后台管理系统标签栏,多标签 *** 作实现方法,第1张

页面实现效果如图:

代码如下:

    // 重新加载
    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()
      }
    },

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1320870.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-11
下一篇 2022-06-11

发表评论

登录后才能评论

评论列表(0条)

保存