Vue+Element UI 侧边导航与标签页同步

在这里插入图片描述

在之前的文章中完成了侧边导航

1、现在完成了侧边导航、标签页和内容的联动,
2、重复点击侧边导航时,标签页不会重复出现,
3、路由状态的保持(切换路由后内容不变化),
4、标签页删除显示右侧标签页(右侧没有则显示左侧)

我看了其他人写的,但是我自己实现的时候始终没有实现,我的是导航栏和标签页可以联动,但标签页和内容不能联动。后来我就干脆不用他们的方法了,跳转路由直接用 this.$router.push() 进行跳转。


原理:
侧边导航和标签页的联动:点击侧边导航时将点击的数据存放到 store 中,然后将数据传回,标签页遍历穿回的数据。

标签页与内容的联动:将标签页的 v-model 设置为点击的页面,同时跳转路由。

避免重复点击:在 store 中存放侧边导航点击数据时,进行判断。如果存在,不存放数据;如果不存在,存放数据

路由状态的保持:在 <router-view> 外嵌套 <keep-alive>

标签页删除:直接套用elementUI的案例

代码:

<!-- 侧边导航 -->
<el-menu
  background-color="#0080c9"
  text-color="#ffffff"
  router
  :default-active="activeIndex"
>
  <!-- 动态渲染导航 -->
  <template v-for="submenu in menuList">
    <el-submenu :index="submenu.id" :key="submenu.id">
      <template slot="title"> {{ submenu.title }} </template>
      <template v-for="menu in submenu.children">
      <!-- 添加标签页的方法 addTab() -->
        <el-menu-item
          :index="menu.index"
          :key="menu.id"
          @click="addTab(menu)"
        >
          {{ menu.childtitle }}
        </el-menu-item>
      </template>
    </el-submenu>
  </template>
</el-menu>
  <!-- 标签栏 -->
  <div class="tabs">
    <el-tabs v-model="activeIndex" @tab-remove="removeTab">
    <!-- :closable 首页不可关闭 -->
      <el-tab-pane
        v-for="item in openTab"
        :key="item.childtitle"
        :label="item.childtitle"
        :name="item.index"
        :closable="item.childtitle !== '首页' "
      >
        <div class="maincontent">
        <!-- keep-alive 保持路由状态 -->
          <keep-alive>
            <router-view name="main"></router-view>
          </keep-alive>
        </div>
      </el-tab-pane>
    </el-tabs>
  </div>

在store中

  state: {
    //所有打开的路由
    openTab: [
      {childtitle: "首页", index: "/homepage/Home" }
    ],
    // 激活状态,侧边导航和标签页的激活状态,初始为首页
    activeIndex: "/homepage/Home",
  },
  mutations: {
    // 单机导航栏时添加标签页
    addTab(state, data) {
      if (state.openTab.indexOf(data) == -1) {
        state.openTab.push(data);
        state.activeIndex=data.index;
      }
      // console.log("aaa",state.openTab)
    },
  },

主页中:

  // 计算属性 从状态管理中获取的数据,因为需要获取和设置store中的数据,所以需要用 get 和 set
  computed: {
    // 已打开的标签页
    openTab: {
      get: function () {
        return this.$store.state.openTab;
      },
      // 用于删除标签页时将删除后的数据传回store
      set: function (newValue) {
        // console.log(newValue);
        this.$store.state.openTab = newValue;
      },
    },
    // 当前标签页
    activeIndex: {
      get: function () {
        return this.$store.state.activeIndex;
      },
      set: function (newValue) {
      	// 当前标签页变化时触发
        // console.log(1111, newValue);
        this.$store.state.activeIndex = newValue;
        this.$router.push(newValue);
      },
    },
  },
  methods: {
    // 从状态管理中获取方法 添加标签页方法
    addTab(data) {
      this.$store.commit("addTab", data);
    },
    // 删除tab,直接在elementUI官网复制的,改了变量名
    removeTab(targetName) {
      // console.log(targetName);
      let tabs = this.openTab;
      let activeIndex = this.activeIndex;
      if (activeIndex === targetName) {
        tabs.forEach((tab, index) => {
          if (tab.index === targetName) {
            let nextTab = tabs[index + 1] || tabs[index - 1];
            if (nextTab) {
              activeIndex = nextTab.index;
            }
          }
        });
      }

      this.activeIndex = activeIndex;
      this.openTab = tabs.filter((tab) => tab.index !== targetName);
    },
  },
  • 10
    点赞
  • 44
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
好的,我来为你解答。 首先,你需要安装 VueElement UI,可以使用以下命令安装: ``` npm install vue npm install element-ui ``` 然后,在你的 Vue 项目中引入 Element UI,在 main.js 中添加以下代码: ``` import Vue from 'vue' import ElementUI from 'element-ui' import 'element-ui/lib/theme-chalk/index.css' Vue.use(ElementUI) ``` 接下来,你就可以在你的 Vue 组件中使用 Element UI 组件了。 下面是一个使用 Element UI 写的登录的例子: ``` <template> <div> <el-form ref="form" :model="form" :rules="rules" label-width="80px"> <el-form-item label="用户名" prop="username"> <el-input v-model="form.username" autofocus></el-input> </el-form-item> <el-form-item label="密码" prop="password"> <el-input v-model="form.password" type="password"></el-input> </el-form-item> <el-form-item> <el-button type="primary" @click="submitForm('form')">登录</el-button> </el-form-item> </el-form> </div> </template> <script> export default { data() { return { form: { username: '', password: '' }, rules: { username: [ { required: true, message: '请输入用户名', trigger: 'blur' } ], password: [ { required: true, message: '请输入密码', trigger: 'blur' } ] } } }, methods: { submitForm(formName) { this.$refs[formName].validate((valid) => { if (valid) { // 发送登录请求 } else { console.log('error submit!!') return false } }) } } } </script> ``` 在这个例子中,我们使用了 Element UI 的 el-form、el-form-item、el-input 和 el-button 组件

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值