当前位置:首页 > VUE

vue 实现页面分栏

2026-02-20 03:17:48VUE

使用 CSS Grid 实现分栏布局

在 Vue 中可以通过 CSS Grid 快速实现分栏布局。定义一个包含多列的网格容器,通过 grid-template-columns 设置列宽比例。

<template>
  <div class="grid-container">
    <div class="left-column">左侧内容</div>
    <div class="right-column">右侧内容</div>
  </div>
</template>

<style>
.grid-container {
  display: grid;
  grid-template-columns: 1fr 2fr; /* 左右列比例1:2 */
  gap: 16px; /* 列间距 */
}
</style>

使用 Flexbox 实现动态分栏

Flexbox 适合需要动态调整的分栏布局,通过 flex 属性控制各栏宽度。

vue 实现页面分栏

<template>
  <div class="flex-container">
    <div class="sidebar" :style="{ width: sidebarWidth + 'px' }">侧边栏</div>
    <div class="main-content">主内容区</div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      sidebarWidth: 200
    }
  }
}
</script>

<style>
.flex-container {
  display: flex;
}
.sidebar {
  flex-shrink: 0;
  background: #f0f0f0;
}
.main-content {
  flex-grow: 1;
}
</style>

响应式分栏切换

结合媒体查询实现移动端折叠为单栏布局。

vue 实现页面分栏

/* 桌面端两栏布局 */
.layout {
  display: grid;
  grid-template-columns: 240px 1fr;
}

/* 移动端单栏布局 */
@media (max-width: 768px) {
  .layout {
    grid-template-columns: 1fr;
  }
}

使用第三方组件库

Element UI 或 Ant Design Vue 等库提供现成的分栏组件:

<template>
  <a-layout>
    <a-layout-sider width="200px">侧边栏</a-layout-sider>
    <a-layout-content>主内容</a-layout-content>
  </a-layout>
</template>

带拖拽调整的分栏实现

通过 vue-draggable 等库实现可调整的分栏宽度:

<template>
  <div class="resizable-layout">
    <div class="left-pane" ref="leftPane">左面板</div>
    <div class="divider" @mousedown="startDrag"></div>
    <div class="right-pane">右面板</div>
  </div>
</template>

<script>
export default {
  methods: {
    startDrag(e) {
      document.addEventListener('mousemove', this.onDrag)
      document.addEventListener('mouseup', this.stopDrag)
    },
    onDrag(e) {
      this.$refs.leftPane.style.width = e.clientX + 'px'
    }
  }
}
</script>

标签: 页面vue
分享给朋友:

相关文章

vue实现缩放

vue实现缩放

Vue 实现缩放的方法 在 Vue 中实现缩放功能可以通过多种方式完成,以下是一些常见的方法: 使用 CSS transform 属性 通过 CSS 的 transform: scale() 属性可…

vue computed实现

vue computed实现

计算属性的基本用法 在Vue中,计算属性通过computed选项定义,用于声明依赖于其他属性的动态值。计算属性基于它们的依赖进行缓存,只有依赖发生变化时才会重新计算。 new Vue({ dat…

vue指令实现

vue指令实现

Vue 指令的实现方式 Vue 指令是特殊的标记,用于在 DOM 元素上应用特定的行为。可以通过全局或局部方式注册自定义指令。 全局注册指令 在 Vue 应用中通过 Vue.directive 方法…

vue实现座位

vue实现座位

Vue实现座位布局 使用Vue实现座位布局可以通过组件化和响应式数据管理来简化开发流程。以下是一个完整的实现方案: 数据准备 定义座位数据结构,通常使用二维数组表示行列关系: data() {…

vue弹幕实现

vue弹幕实现

Vue弹幕实现方法 弹幕功能常见于视频直播或评论区,以下是基于Vue的实现方案,涵盖基础弹幕、动画控制及性能优化。 基础弹幕渲染 通过v-for动态渲染弹幕列表,结合CSS实现横向移动效果。…

vue实现图片预览

vue实现图片预览

Vue 实现图片预览的方法 使用 Element UI 的 el-image 组件 Element UI 提供了 el-image 组件,支持图片预览功能。通过设置 preview-src-list…