layui水平导航条三级
需求
需要做一个顶部的水平导航条,有三级,展开的时候二级和三级一起展开,结果如图:
效果
代码
下面贴上代码:
HTML代码
<div class="layui-header">
<ul id="moudleMenu" class="layui-nav layui-layout-left kit-nav">
<li class="layui-nav-item nav-custom"><a href="javascript:;">一级菜单</a>
<div class="layui-nav-child layui-anim layui-anim-upbit">
<ul style="float: left; text-align: center; color: black; margin: 0;">
<li>
<span>二级标题</span>
<!-- 标题下面的线 -->
<div style="height: 1px; background-color: #1e9fff; width: 90%; margin: 0 auto;"> </div>
</li>
<li><a style="padding: 0;" href="'javascript:void(0);"><span>三级菜单</span></a></li>
<li><a style="padding: 0;" href="'javascript:void(0);"><span>三级菜单</span></a></li>
</ul>
<ul style="float: left; text-align: center; color: black; margin: 0;">
<li>
<span>二级标题</span>
<div style="height: 1px; background-color: #1e9fff; width: 90%; margin: 0 auto;"> </div>
</li>
<li><a style="padding: 0;" href="'javascript:void(0);"><span>三级菜单</span></a></li>
<li><a style="padding: 0;" href="'javascript:void(0);"><span>三级菜单</span></a></li>
</ul>
</div>
</li>
<li class="layui-nav-item nav-custom"><a href="javascript:;">一级菜单</a>
<div class="layui-nav-child layui-anim layui-anim-upbit">
<ul style="float: left; text-align: center; color: black; margin: 0;">
<li>
<span>二级标题</span>
<div style="height: 1px; background-color: #1e9fff; width: 90%; margin: 0 auto;"> </div>
</li>
<li><a style="padding: 0;" href="'javascript:void(0);"><span>三级菜单</span></a></li>
<li><a style="padding: 0;" href="'javascript:void(0);"><span>三级菜单</span></a></li>
<li><a style="padding: 0;" href="'javascript:void(0);"><span>三级菜单</span></a></li>
</ul>
<ul style="float: left; text-align: center; color: black; margin: 0;">
<li>
<span>二级标题</span>
<div style="height: 1px; background-color: #1e9fff; width: 90%; margin: 0 auto;"> </div>
</li>
<li><a style="padding: 0;" href="'javascript:void(0);"><span>三级菜单</span></a></li>
<li><a style="padding: 0;" href="'javascript:void(0);"><span>我是独特的三级菜单</span></a></li>
<li><a style="padding: 0;" href="'javascript:void(0);"><span>三级菜单</span></a></li>
</ul>
<ul style="float: left; text-align: center; color: black; margin: 0;">
<li>
<span>二级标题</span>
<div style="height: 1px; background-color: #1e9fff; width: 90%; margin: 0 auto;"> </div>
</li>
<li><a style="padding: 0;" href="'javascript:void(0);"><span>三级菜单</span></a></li>
<li><a style="padding: 0;" href="'javascript:void(0);"><span>三级菜单</span></a></li>
</ul>
</div>
</li>
<li class="layui-nav-item nav-custom"><a href="javascript:;">一级菜单</a>
<div class="layui-nav-child layui-anim layui-anim-upbit">
<ul style="float: left; text-align: center; color: black; margin: 0;">
<li><a style="padding: 0;" href="'javascript:void(0);"><span>我上面的二级标题呢</span></a></li>
<li><a style="padding: 0;" href="'javascript:void(0);"><span>我是三级</span></a></li>
</ul>
</div>
</li>
</ul>
</div>
需要加上一个css .layui-nav-child{top:60px !important;}
JS代码:
引用jQuery、layui.js、layui.css和element.js文件
layui.use('element', function(){
var element = layui.element;
element.init();
//如果不把layui自带的滑动线移除,会导致子菜单隐藏
$(".layui-nav-bar").css("display","none");
//鼠标悬浮
navMouseOver();
//鼠标移出
navMouseOut();
});
//当鼠标经过时 设置展开菜单的宽度及位置的CSS样式
function navMouseOver() {
$(".nav-custom").each(function() {
$(this).mouseover(function () {
//当鼠标放上时显示子菜单
$(this).children("div").css("visibility", "visible");
$(this).children("div").children("ul").children("li").children("a").children("span").css("visibility", "visible");
//ul的个数
var ulCount = $(this).children("div").children("ul").length;
//li的个数
var liCount = $(this).children("div").children("ul").children("li").length;
//定义字符最大长度
var maxLength = 0;
//遍历当前展开菜单的li
$(this).children("div").children("ul").children("li").each(function() {
//获取展开菜单的标题字符数
if ($(this).children("span").text().length > maxLength) {
maxLength = $(this).children("span").text().length; }
//获取展开菜单的选择项的字符数
if ($(this).children("span").text() == "") {
if ($(this).children("a").children("span").text().length > maxLength) {
maxLength = $(this).children("a").children("span").text().length;
}
}
});
//每个子菜单的ul长度 为最长字符数*字符像素px+左右空白间隔
var width = maxLength * 13 + 40;
//设置展开菜单的每个子菜单的ul长度 为最长字符数*字符像素px
$(".nav-custom").children("div").children("ul").css("width", width + "px");
//设置展开菜单的总div宽度 为子菜单的ul长度*子菜单ul个数
$(".nav-custom").children("div").css("width", width * ulCount + "px");
//设置展开菜单的总div偏移居中
$(".nav-custom").children("div").css("left", (-1 * width * ulCount) / 2 + ($(".nav-custom").width()) / 2 + "px");
});
});
}
//当鼠标移出时,立即隐藏子菜单(因为不设置隐藏的话,来回切会有延迟导致未隐藏的子菜单变形)
function navMouseOut() {
$(".nav-custom").each(function () {
$(this).mouseout(function () {
//设置div不可见
$(this).children("div").css("visibility", "hidden");
//设置div中的字不可见
$(this).children("div").children("ul").children("li").children("a").children("span").css("visibility", "hidden");
});
});
}
样式的话,按照自己喜欢的调吧(`・ω・´)
layui水平导航条三级的更多相关文章
- CSS水平导航条和纵向导航条
问题描述: 使用CSS制作水平导航条和纵向导航条 问题解决: (1)水平导航条 1.1 效果预览: 1.2 ...
- HTML布局水平导航条2制作
前两个博文导航条都不是铺满水平的浏览器的,很多导航条样式都是随着浏览器的移动,是100%.此外前两个博文导航条都是块状点击的,也就是给a标签加宽高,设置成块状显示,点击的时候不一定要点文字,只要点击该 ...
- HTML布局水平导航条1制作
该文是用css制作个导航条,用竖线分隔,导航条是点击的多个区块.步骤:ul里设置需要数量的li,li中加上a链接给ul加样式,去掉默认的前面的点给li设置左浮动,让ul里的li横向排列a链接设置成块状 ...
- div自定义的滚动条 (水平导航条)
<!DOCTYPE html> <html> <head> <title></title> <style> div{ /* wi ...
- simple水平导航条
话不多说,看代码: html部分 <body> <ul> <li><a href="#">Home</a></li ...
- css -- 导航条
1.垂直导航条 HTML: <ul class="nav"> <li><a href="">Home</a>&l ...
- CSS列表及导航条
大多数网页中都包含某种形式的列表,今天我们就来联系几个基本的导航条. 垂直导航条 注意要点: 去掉默认的项目符号(list-style-type:none),将外边距和内边距都设为0. 以em设置 ...
- [前端]如何写一个水平导航栏?(浮动、inline-block+消除间距)
在看W3school时,看到一个很好的例子,如何制作一个水平的导航栏?没有任何要求,只需要达到下面的效果: 我认为这个例子包含了很多css布局需要了解的知识,因此单独写一下. W3school上面的方 ...
- ch6 列表和导航条
为列表添加定制的项目符号 可使用list-style-image属性:缺点是对项目符号图像的位置的控制能力不强. 常用的方法:使用list-style-type来关闭项目符号,将定制的项目符号作为背景 ...
随机推荐
- Eclipse 配置 maven 的两个 settings 文件
eclipse配置的settings文件名完全可以自定义,而本机maven只认识settings.xml文件. eclipse里配置maven有一个叫全局的,有一个叫用户的.这两个文件可以和本机mav ...
- shiro web 集成
集成方法 shiro与web集成,主要是通过配置一个ShiroFilter拦截所有URL,其中ShiroFilter类似于SpringMVC的前端控制器,是所有请求入口点,负责根据配置(如ini配置文 ...
- 课后作业week 5 —— 两款修图软件优势及创新分析
由于我平时没事也会修修照片什么的,也用过一些不同种类的修图软件,这次作业就选择了其中两款比较热门的软件进行分析. 说到手机修图app,很多人很容易想到“美图秀秀”,的确这款app在修图软件领域的确算的 ...
- ALTER 语句总结
一.基础语句 ALTER TABLE 语句 ALTER TABLE 语句用于在现有表中添加.删除或修改列. <!--若要向表中添加列,请使用以下语法:--> ALTER TABLE tab ...
- armel和armhf区别
出于低功耗.封装限制等种种原因,之前的一些ARM架构处理器因为内部资源宝贵,加入浮点运算单元是十分奢侈的,因为需要额外的软件实现.之前的ARM处理器架构是什么样的?(http://www.cnblog ...
- 分享:Windows2008重启后提示系统恢复选项的解决办法
如题:WINdows2008服务器. 重启后提示系统恢复选项的解决办法 使用windows 2008后,不能启动的问题,重启后出现 修复系统选项 采用下面帖子中的部分命令搞定之. 我自己是直接使用:选 ...
- 在 Azure 中的 Linux 虚拟机上使用 SSL 证书保护 Web 服务器
若要保护 Web 服务器,可以使用安全套接字层 (SSL) 证书来加密 Web 流量. 这些 SSL 证书可存储在 Azure Key Vault 中,并可安全部署到 Azure 中的 Linux 虚 ...
- procexp
https://www.cnblogs.com/iTBear/articles/2789151.html
- Linux 系统磁盘挂载信息文件
设置文件系统挂载信息的文件(etc/fstab),使得开机能够自动挂载磁盘分区 文件系统挂载 方法一: 直接挂在,临时生效 # 格式化系统(没有格式化就没有文件系统,放不了数据) dd if=/dev ...
- nodejs API(一)
不要注重版本 URL 官网所在位置:https://nodejs.org/dist/latest-v8.x/docs/api/url.html URL网址解析的好帮手: url有三个可调用的方法:ur ...