当前位置: 首页 > article >正文

vue中将侧边栏隐藏

对于一些系统网站,我们通常都会存在侧边导航栏,有些场景下,我们需要将它隐藏掉,那要如何实现呢?

这里记录一种思路:

我们可以通过小图标的点击,实现隐藏和展开。 主要原理就是 利用leftWidth变量动态设置css样式

我们分别找到两个小图标,对应点击展开和点击隐藏。

然后给左侧导航栏和右侧主界面动态的设置css样式(初始leftWidth为18,也就是左侧导航栏的宽度占比)

<template>
  <div class="root">
    <div class="container">
      <img src="./assets/images/rightbar.png" alt="" title="点击展开" v-if="this.leftWidth<2" @click="openList" class="menu_Open">

      <!-- menu_list 列表 -->
      <div class="list" :style="{width: leftWidth + '%'}">
        <img src="./assets/images/leftbar.png" title="点击收起" alt="" class="menu_Close" @click="closeList">
        <div v-for="item in menu_list" :key="item.id">{{item.id}} - {{item.name}}</div>
      </div>

      <!-- main 页面 -->
      <div :style="{width: (100 - leftWidth) + '%'}" class="mainPage">
        <h1>This is the Main Page!</h1>
      </div>
    </div>
  </div>
</template>

<script>
export default {
  name: 'App',
  components:{

  },
  data(){
    return {
      leftWidth: 18,
      menu_list: [
        {
          id: 1,
          name: '列表1'
        },
        {
          id: 2,
          name: '列表2'
        },
        {
          id: 3,
          name: '列表3'
        },
      ]
    }
  },
  methods: {
    openList(){
      this.leftWidth = 18
      console.log('open',this.leftWidth);

    },
    closeList(){
      this.leftWidth = 0;
      console.log('close',this.leftWidth);
    }
  }
}
</script>

<style>
html,body {
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
}
#app {
  font-family: Avenir, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  height: 100%;
  width: 100%;
  background: gray;
}

.root {
  height: 100%;
}

.container {
  display: flex;
  position: relative;
  height: 100%;
  text-align: center;
}
/* 侧边导航栏 */
.list {
  border-right: 1px solid rgb(64, 85, 122);
  padding-top: 10px;
  box-sizing: border-box;
  height: 100%;
  position: relative;
  overflow: hidden;
}
/* 关闭侧边栏 小图标 */
.menu_Close {
  width: 20px;
  height: 20px;
  position: absolute;
  right: 0;
  top: 10px;
  opacity: 0.7;
  cursor: pointer;
} 
/* 展开侧边栏 小图标 */
.menu_Open {
  width: 20px;
  height: 20px;
  position: absolute;
  left: 0;
  top: 10px;
  opacity: 0.7;
  cursor: pointer;
  z-index: 99999;
}
/* 右侧主要页面 */
.mainPage {
  padding: 10px;
}
</style>

也可以修改各个值的参数来自定义布局,比如 左侧导航栏展开和隐藏后的宽度,可以通过leftWidth设置, 小图标的具体位置,可以通过left和top的值设置


http://www.kler.cn/news/9586.html

相关文章:

  • Linux防火墙开放端口
  • 如何使用 Jetpack Compose 创建翻转卡片效果
  • Java基础(五)面向对象编程(基础)
  • Keil 5 安装教程及简单使用【嵌入式系统】
  • JavaScript+Selenium自动化测试
  • 记一次 .NET 某医疗住院系统 崩溃分析
  • 堡垒机主流品牌有哪些?如何选择?
  • 【LeetCode每日一题: 1312. 让字符串成为回文串的最少插入次数 | 暴力递归=>记忆化搜索=>动态规划 | 区间dp 】
  • Maven配置私服
  • 行为型模式-责任链模式
  • this指向问题
  • nginx--基本配置
  • leetcode 917 仅仅反转字母
  • 爱创科技携手“中华老字号”卫岗乳业,携手爱创科技,解码AR营销
  • Linux常见操作命令【二】
  • substr | mysql
  • DNS配置
  • (函数指针) 指向函数的指针
  • cephadm离线部署及curushmap
  • 2023年全国最新保安员精选真题及答案48
  • 打怪升级之FPGA组成原理(LE部分)
  • 关于linux的chnod问题
  • 让代码变得优雅简洁的神器:Java8 Stream流式编程
  • [自注意力神经网络]Segment Anything(SAM)论文阅读
  • 如何避免 MyBatis 查询导致的内存溢出:配置与策略指南
  • Python-代码阅读-图像处理的类 ImageProcess
  • pc端页面嵌入,同源,app无内容,页面空白问题(vite)
  • 微信小程序引入骨架屏
  • pinia的使用以及持久化存储
  • JS中的宏任务与微任务