当前位置:首页 > VUE

vue实现左侧抽屉

2026-02-20 04:41:53VUE

Vue 实现左侧抽屉

使用 Vue 实现左侧抽屉可以通过多种方式完成,以下是几种常见的方法:

使用 Element UI 的 Drawer 组件

Element UI 提供了现成的 Drawer 组件,可以快速实现左侧抽屉效果。

安装 Element UI:

npm install element-ui

在 Vue 文件中引入并使用 Drawer 组件:

<template>
  <div>
    <el-button @click="drawer = true" type="primary">打开抽屉</el-button>
    <el-drawer
      title="标题"
      :visible.sync="drawer"
      direction="ltr"
      :before-close="handleClose">
      <span>抽屉内容</span>
    </el-drawer>
  </div>
</template>

<script>
export default {
  data() {
    return {
      drawer: false
    }
  },
  methods: {
    handleClose(done) {
      // 关闭前的回调
      done()
    }
  }
}
</script>

使用 Vue 原生实现

如果不依赖第三方库,可以通过 Vue 的原生功能实现抽屉效果。

<template>
  <div>
    <button @click="toggleDrawer">打开抽屉</button>
    <div class="drawer" :class="{ 'drawer-open': isOpen }">
      <div class="drawer-content">
        <span>抽屉内容</span>
        <button @click="toggleDrawer">关闭</button>
      </div>
    </div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      isOpen: false
    }
  },
  methods: {
    toggleDrawer() {
      this.isOpen = !this.isOpen
    }
  }
}
</script>

<style>
.drawer {
  position: fixed;
  top: 0;
  left: -300px;
  width: 300px;
  height: 100%;
  background: #fff;
  box-shadow: 2px 0 5px rgba(0, 0, 0, 0.1);
  transition: left 0.3s ease;
}
.drawer-open {
  left: 0;
}
</style>

使用 Vuetify 的 Navigation Drawer

Vuetify 也提供了 Navigation Drawer 组件,适合 Material Design 风格的应用。

安装 Vuetify:

npm install vuetify

在 Vue 文件中使用 Navigation Drawer:

<template>
  <v-app>
    <v-navigation-drawer v-model="drawer" absolute temporary>
      <v-list>
        <v-list-item>
          <v-list-item-content>
            <v-list-item-title>抽屉内容</v-list-item-title>
          </v-list-item-content>
        </v-list-item>
      </v-list>
    </v-navigation-drawer>
    <v-btn @click="drawer = !drawer">打开抽屉</v-btn>
  </v-app>
</template>

<script>
export default {
  data() {
    return {
      drawer: false
    }
  }
}
</script>

使用 CSS 过渡效果

可以通过 CSS 过渡效果增强抽屉的打开和关闭动画。

vue实现左侧抽屉

<template>
  <div>
    <button @click="toggleDrawer">打开抽屉</button>
    <div class="drawer-overlay" v-if="isOpen" @click="toggleDrawer"></div>
    <div class="drawer" :class="{ 'drawer-open': isOpen }">
      <span>抽屉内容</span>
    </div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      isOpen: false
    }
  },
  methods: {
    toggleDrawer() {
      this.isOpen = !this.isOpen
    }
  }
}
</script>

<style>
.drawer-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  z-index: 999;
}
.drawer {
  position: fixed;
  top: 0;
  left: -300px;
  width: 300px;
  height: 100%;
  background: #fff;
  z-index: 1000;
  transition: transform 0.3s ease;
}
.drawer-open {
  transform: translateX(300px);
}
</style>

以上方法可以根据项目需求选择适合的方式实现左侧抽屉功能。

标签: 抽屉vue
分享给朋友:

相关文章

vue实现3d宇宙

vue实现3d宇宙

Vue实现3D宇宙效果 使用Three.js库 Three.js是一个强大的JavaScript 3D库,可以轻松集成到Vue项目中。安装Three.js依赖: npm install three…

vue实现积分

vue实现积分

Vue 实现积分功能 在 Vue 中实现积分功能通常涉及前端展示、交互逻辑以及与后端 API 的通信。以下是常见的实现方法和步骤: 积分展示组件 创建一个积分展示组件,用于显示当前用户的积分。可以使…

vue筛选实现

vue筛选实现

Vue 筛选实现方法 使用计算属性实现筛选 计算属性是 Vue 中实现数据筛选的常用方式。通过定义一个计算属性,可以根据输入的条件动态过滤数据。 <template> <div…

vue底层实现

vue底层实现

Vue.js 的底层实现原理 Vue.js 是一个渐进式 JavaScript 框架,其核心实现主要包括响应式系统、虚拟 DOM、模板编译和组件化机制。以下是其关键实现细节: 响应式系统 Vue 2…

vue实现CRUD

vue实现CRUD

Vue 实现 CRUD 操作 Vue 提供了响应式数据绑定和组件化开发能力,结合后端 API 可以轻松实现 CRUD(增删改查)功能。以下是基于 Vue 3 和 Axios 的完整实现方案。 安装依…

vue实现绘图

vue实现绘图

Vue 实现绘图的方法 在 Vue 中实现绘图功能,可以通过多种方式实现,包括使用原生 HTML5 Canvas、第三方库(如 Fabric.js、Konva.js)或 SVG。以下是几种常见的实现方…