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的值设置

您可以使用Vue和Element UI来创建一个登录界面,并设置一个侧边栏。以下是一个示例代码,可以帮助您开始: 首先,您需要安装Vue和Element UI。在命令行中运行以下命令来安装它们: ```bash npm install vue npm install element-ui ``` 然后,创建一个Login.vue组件,用于渲染登录界面的内容: ```vue <template> <div class="login-container"> <h2>Login</h2> <el-form ref="loginForm" :model="loginForm" :rules="loginRules" label-width="80px"> <el-form-item label="Username" prop="username"> <el-input v-model="loginForm.username"></el-input> </el-form-item> <el-form-item label="Password" prop="password"> <el-input type="password" v-model="loginForm.password"></el-input> </el-form-item> <el-form-item> <el-checkbox v-model="loginForm.remember">Remember me</el-checkbox> </el-form-item> <el-form-item> <el-button type="primary" @click="login">Login</el-button> </el-form-item> </el-form> </div> </template> <script> export default { data() { return { loginForm: { username: '', password: '', remember: false }, loginRules: { username: [ { required: true, message: 'Please enter your username', trigger: 'blur' } ], password: [ { required: true, message: 'Please enter your password', trigger: 'blur' } ] } }; }, methods: { login() { this.$refs.loginForm.validate(valid => { if (valid) { // Perform login logic here } else { return false; } }); } } }; </script> <style scoped> .login-container { width: 300px; margin: 0 auto; padding-top: 100px; } </style> ``` 接下来,创建一个Sidebar.vue组件,用于渲染侧边栏的内容: ```vue <template> <div class="sidebar-container"> <h3>Sidebar</h3> <el-menu default-active="1" @select="handleMenuSelect"> <el-menu-item index="1">System Admin</el-menu-item> <el-menu-item index="2">School Admin</el-menu-item> <el-menu-item index="3">User</el-menu-item> <el-menu-item index="4">Guest</el-menu-item> </el-menu> </div> </template> <script> export default { methods: { handleMenuSelect(index) { // Show login form based on selected menu item switch (index) { case '1': // Show system admin login form break; case '2': // Show school admin login form break; case '3': // Show user login form break; case '4': // Show guest login form break; } } } }; </script> <style scoped> .sidebar-container { width: 200px; background-color: #f0f0f0; padding: 20px; } </style> ``` 最后,在App.vue组件中将Login和Sidebar组件组合在一起: ```vue <template> <div class="app-container"> <sidebar></sidebar> <login></login> </div> </template> <script> import Sidebar from './Sidebar.vue'; import Login from './Login.vue'; export default { components: { Sidebar, Login } }; </script> <style> .app-container { display: flex; } </style> ``` 现在,您可以在应用程序中使用App.vue组件作为入口点,并在浏览器中运行它。这样,您将看到一个具有侧边栏和登录界面的界面。当选择不同的菜单项时,登录界面会根据所选项进行更新。 请注意,此示例只提供了界面的基本结构和样式,并未包含实际的登录逻辑。您需要根据自己的需求来实现实际的登录功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值