基于vue.js实现侧边菜单栏

发布时间 - 2026-01-11 00:15:42    点击率:

侧边菜单栏应该是很多项目里必不可少的,自己手写了一个

下面是效果图

 

下面就说一下实现的过程 还是比较简单的
首先导入一下需要的文件

<link rel="stylesheet" type="text/css" href="bootstrap/css/bootstrap.min.css" rel="external nofollow" >
<link rel="stylesheet" type="text/css" href="css/font-awesome.min.css" rel="external nofollow" >
<link rel="stylesheet" type="text/css" href="css/nav.css" rel="external nofollow" >
<script type="text/javascript" src="js/jquery.min.js"></script>
<script type="text/javascript" src="bootstrap/js/bootstrap.min.js"></script>

接下来就是我的html

<nav class="sider-bar small-bar">
 <ul>
  <li class="home_btn">
   <a href="javascript:;" id="full-bar" >
    <i class="fa fa-navicon nav_icon"></i>
   </a>
  </li>
  <li>
   <a href="javascript:;">
    <i class="fa fa-home nav_icon"></i>
    <span class="nav-text">主页</span>
   </a>
  </li>
  <li class="drop-show">
   <a href="javascript:;" >
    <i class="fa fa-cogs nav_icon"></i>
    <span class="nav-text">系统<i class="fa fa-angle-right nav_icon "></i></span>

   </a>
   <ul class="drop-list">
    <li><a href="user.html">用户管理</a></li>
    <li><a href="buttons.html">权限设置</a></li>
    <li><a href="buttons.html">操作日志</a></li>
    <li><a href="buttons.html">设备运行日志</a></li>
   </ul>
  </li>
  <li class="drop-show">
   <a href="javascript:;">
    <i class="fa fa-check-square-o nav_icon"></i>
    <span class="nav-text">防区 <i class="fa fa-angle-right nav_icon "></i></span>
   </a>
   <ul class="drop-list">
    <li><a href="buttons.html">防区管理</a></li>
   </ul>
  </li>
  <li class="drop-show">
   <a href="javascript:;">
    <i class="fa fa-info-circle nav_icon"></i>
    <span class="nav-text">警报 <i class="fa fa-angle-right nav_icon "></i></span>
   </a>
   <ul class="drop-list">
    <li><a href="buttons.html">历史报警曲线</a></li>
    <li><a href="buttons.html">报表统计</a></li>
    <li><a href="buttons.html">警情处理</a></li>
   </ul>
  </li>
  <li>
   <a href="#">
    <i class="fa fa-dashboard (alias) nav_icon"></i>
    <span class="nav-text">设备</span>
   </a>
  </li>
 </ul>
</nav>

然后是css

* {
 margin: 0;
 padding: 0;
}
body {
 font-family:Microsoft YaHei;
 font-size:14px;
}
li,ol,ul {
 list-style: none;
}
a {
 text-decoration: none;
 outline: 0;
}
a:hover,a:link{
 text-decoration:none;
}
.sider-bar{ 
 float:left;
 width:220px; 
 height:100%; 
 z-index:999;
 overflow:hidden;
 background:rgba(0,0,0,0.7); 
}
.sider-bar ul{ 
 width:100%; 
 float:left
}
.sider-bar ul li{ 
 width:100%; 
 float:left; 
 font-size:14px;
}
.sider-bar ul li a{ 
 padding:8px 10px;
 display:block;
 color:#fff; 
}
.sider-bar ul li.home_btn{ 
 background:#282D2D; 
 text-align:center
}
.sider-bar ul li.home_btn:hover{ 
 background:#282D2D
}
.sider-bar ul li a:hover{ 
 background:#0099CC;
}
.sider-bar ul li .nav_icon{ 
 font-size:18px; 
 margin:0 5px;
}
.small-bar{
 width:50px;
}
.small-bar li { 
 text-align:center;
}
.small-bar li a{
 display:block; 
 text-align:center
}
.small-bar li span{ 
 display:none
}
.small-bar ul li .nav_icon{ 
 font-size:24px; 
 margin:0
}
ul.drop-list{ 
 display:none; 
 margin-left:30px; 
 width:190px;
}
.fa-angle-right{ 
 float:right
}
body, html {
 height:100%;
}

最后也就是我的js

$(document).ready(function(){
 //展开主菜单
 $("#full-bar").click(function(){
  $(".sider-bar").toggleClass("small-bar");
  if($(".sider-bar").hasClass('small-bar')){
   $(".drop-list").slideUp();
  }
 });
 $(".drop-show").click(function(){
  if(!$(".sider-bar").hasClass('small-bar')){
   $(this).children(".drop-list").slideToggle();
   $(this).siblings('li').children(".drop-list").slideUp();
  }
 });
});

本文已被整理到了《Vue.js前端组件学习教程》,欢迎大家学习阅读。

关于vue.js组件的教程,请大家点击专题vue.js组件学习教程进行学习。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# vue.js  # 菜单栏  # js实现顶部可折叠的菜单工具栏效果实例  # Extjs学习笔记之四 工具栏和菜单  # JS实现自动固定顶部的悬浮菜单栏效果  # 使用ReactJS实现tab页切换、菜单栏切换、手风琴切换和进度条效果  # 简单实现js菜单栏切换效果  # 原生JS仿苹果任务栏菜单  # 放大效果的菜单  # JS实现仿苹果底部任务栏菜单效果代码  # JavaScript NodeTree导航栏(菜单项JSON类型/自制)  # 非常酷的js图形渐隐导航菜单栏  # JS实现左侧菜单工具栏  # 已被  # 请大家  # 写了  # 欢迎大家  # 就说  # 必不可少  # 大家多多  # 应该是  # bar  # sider  # html  # li  # ul  # small  # jquery  # script  # nav  # awesome  # js  # src 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel Seeder填充数据教程_Laravel模型工厂Factory使用  详解Huffman编码算法之Java实现  php中::能调用final静态方法吗_final修饰静态方法调用规则【解答】  佐糖AI抠图怎样调整抠图精度_佐糖AI精度调整与放大细化操作【攻略】  中山网站推广排名,中山信息港登录入口?  Laravel如何集成Inertia.js与Vue/React?(安装配置)  如何用AWS免费套餐快速搭建高效网站?  今日头条AI怎样推荐抢票工具_今日头条AI抢票工具推荐算法与筛选【技巧】  如何登录建站主机?访问步骤全解析  标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?  大型企业网站制作流程,做网站需要注册公司吗?  如何快速生成ASP一键建站模板并优化安全性?  Laravel的辅助函数有哪些_Laravel常用Helpers函数提高开发效率  laravel怎么在请求结束后执行任务(Terminable Middleware)_laravel Terminable Middleware请求结束任务执行方法  Laravel如何实现本地化和多语言支持?(i18n教程)  Laravel如何设置自定义的日志文件名_Laravel根据日期或用户ID生成动态日志【技巧】  Windows驱动无法加载错误解决方法_驱动签名验证失败处理步骤  php在windows下怎么调试_phpwindows环境调试操作说明【操作】  微信小程序 input输入框控件详解及实例(多种示例)  Laravel如何获取当前用户信息_Laravel Auth门面获取用户ID  laravel怎么为API路由添加签名中间件保护_laravel API路由签名中间件保护方法  lovemo网页版地址 lovemo官网手机登录  JavaScript数据类型有哪些_如何准确判断一个变量的类型  Laravel如何为API编写文档_Laravel API文档生成与维护方法  购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?  Win10如何卸载预装Edge扩展_Win10卸载Edge扩展教程【方法】  javascript如何操作浏览器历史记录_怎样实现无刷新导航  北京网站制作公司哪家好一点,北京租房网站有哪些?  在线制作视频的网站有哪些,电脑如何制作视频短片?  Win11怎么关闭资讯和兴趣_Windows11任务栏设置隐藏小组件  🚀拖拽式CMS建站能否实现高效与个性化并存?  如何在云虚拟主机上快速搭建个人网站?  ,网页ppt怎么弄成自己的ppt?  HTML 中如何正确使用模板变量为元素的 name 属性赋值  如何用PHP快速搭建CMS系统?  中国移动官方网站首页入口 中国移动官网网页登录  如何在云主机上快速搭建多站点网站?  制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?  Midjourney怎样加参数调细节_Midjourney参数调整技巧【指南】  Edge浏览器如何截图和滚动截图_微软Edge网页捕获功能使用教程【技巧】  Laravel如何实现登录错误次数限制_Laravel自带LoginThrottles限流配置【方法】  如何在橙子建站上传落地页?操作指南详解  php做exe能调用系统命令吗_执行cmd指令实现方式【详解】  Laravel怎么在Blade中安全地输出原始HTML内容  Laravel路由Route怎么设置_Laravel基础路由定义与参数传递规则【详解】  详解阿里云nginx服务器多站点的配置  如何快速建站并高效导出源代码?  node.js报错:Cannot find module &#39;ejs&#39;的解决办法  公司门户网站制作流程,华为官网怎么做?  详解Oracle修改字段类型方法总结