当前位置:首页 > VUE

vue实现左右菜单

2026-01-08 06:18:28VUE

实现左右菜单的基本思路

使用Vue实现左右菜单通常需要两个主要组件:左侧的导航菜单和右侧的内容区域。左侧菜单用于导航,右侧区域根据菜单选择动态展示内容。

创建左侧菜单组件

左侧菜单通常是一个列表,可以使用Vue的v-for指令动态生成菜单项。每个菜单项绑定点击事件,用于切换右侧内容。

<template>
  <div class="left-menu">
    <ul>
      <li 
        v-for="(item, index) in menuItems" 
        :key="index"
        @click="selectMenuItem(index)"
        :class="{ active: activeIndex === index }"
      >
        {{ item.title }}
      </li>
    </ul>
  </div>
</template>

<script>
export default {
  data() {
    return {
      menuItems: [
        { title: '菜单项1', content: '内容1' },
        { title: '菜单项2', content: '内容2' },
        { title: '菜单项3', content: '内容3' }
      ],
      activeIndex: 0
    }
  },
  methods: {
    selectMenuItem(index) {
      this.activeIndex = index
      this.$emit('menu-change', this.menuItems[index].content)
    }
  }
}
</script>

<style>
.left-menu {
  width: 200px;
  background: #f0f0f0;
}
.left-menu ul {
  list-style: none;
  padding: 0;
}
.left-menu li {
  padding: 10px;
  cursor: pointer;
}
.left-menu li.active {
  background: #ddd;
}
</style>

创建右侧内容组件

右侧内容组件接收来自左侧菜单的内容并显示。

<template>
  <div class="right-content">
    {{ content }}
  </div>
</template>

<script>
export default {
  props: {
    content: {
      type: String,
      default: '请选择菜单项'
    }
  }
}
</script>

<style>
.right-content {
  flex: 1;
  padding: 20px;
}
</style>

组合左右组件

在主组件中将左右菜单组合起来,并通过事件通信实现联动。

<template>
  <div class="container">
    <LeftMenu @menu-change="updateContent" />
    <RightContent :content="currentContent" />
  </div>
</template>

<script>
import LeftMenu from './LeftMenu.vue'
import RightContent from './RightContent.vue'

export default {
  components: {
    LeftMenu,
    RightContent
  },
  data() {
    return {
      currentContent: ''
    }
  },
  methods: {
    updateContent(content) {
      this.currentContent = content
    }
  }
}
</script>

<style>
.container {
  display: flex;
  height: 100vh;
}
</style>

使用Vue Router实现路由切换

如果需要更复杂的导航,可以结合Vue Router实现路由级别的左右菜单。

// router.js
import Vue from 'vue'
import Router from 'vue-router'
import Page1 from './views/Page1.vue'
import Page2 from './views/Page2.vue'

Vue.use(Router)

export default new Router({
  routes: [
    { path: '/page1', component: Page1 },
    { path: '/page2', component: Page2 }
  ]
})

修改左侧菜单组件使用router-link

<template>
  <div class="left-menu">
    <ul>
      <li v-for="(item, index) in menuItems" :key="index">
        <router-link :to="item.path">{{ item.title }}</router-link>
      </li>
    </ul>
  </div>
</template>

<script>
export default {
  data() {
    return {
      menuItems: [
        { title: '页面1', path: '/page1' },
        { title: '页面2', path: '/page2' }
      ]
    }
  }
}
</script>

响应式布局调整

为适应不同屏幕尺寸,可以添加媒体查询调整布局。

@media (max-width: 768px) {
  .container {
    flex-direction: column;
  }
  .left-menu {
    width: 100%;
    height: auto;
  }
}

使用状态管理

对于复杂应用,可以使用Vuex管理菜单状态。

// store.js
import Vue from 'vue'
import Vuex from 'vuex'

Vue.use(Vuex)

export default new Vuex.Store({
  state: {
    activeMenu: 'home'
  },
  mutations: {
    setActiveMenu(state, menu) {
      state.activeMenu = menu
    }
  }
})

在组件中提交mutation:

this.$store.commit('setActiveMenu', 'newMenu')

vue实现左右菜单

标签: 菜单vue
分享给朋友:

相关文章

vue实现防抖节流

vue实现防抖节流

Vue 中实现防抖(Debounce) 防抖的核心是延迟执行函数,在连续触发时取消前一次的调用,只执行最后一次。适用于输入框搜索、窗口大小调整等场景。 方法1:使用 Lodash 的 _.debo…

vue实现全局遮罩层

vue实现全局遮罩层

实现全局遮罩层的方法 在Vue中实现全局遮罩层可以通过多种方式完成,以下是几种常见的实现方法: 使用Vue组件创建遮罩层 创建一个遮罩层组件,通过全局注册或动态挂载的方式实现全局调用。以下是一个简单…

vue实现visual

vue实现visual

Vue 实现可视化(Visual)的常见方法 在 Vue 中实现可视化通常涉及数据可视化库的集成,以下是几种主流方案: 使用 ECharts ECharts 是一个强大的 JavaScript…

vue实现语音

vue实现语音

Vue 实现语音功能的方法 使用 Web Speech API Vue 可以结合 Web Speech API 实现语音识别和合成功能。Web Speech API 包含 SpeechRecognit…

vue实现闪烁

vue实现闪烁

Vue实现元素闪烁效果 使用CSS动画实现 通过Vue绑定class结合CSS动画实现闪烁效果,代码简洁且性能较好。 <template> <div :class="{ 'b…

vue实现cs

vue实现cs

Vue 实现 CS(Client-Side)渲染的常见方法 Vue.js 是一个用于构建用户界面的渐进式框架,默认采用客户端渲染(CSR)。以下是几种常见的实现方式: 使用 Vue CLI 创建项…