在项目需求中打开的模块页面总是在一个总视图中去显示,其实在用户体验中不算太好,因为用户在A页面操作时可能需要同时去查看B页面,并且在切换页面的时候页面会进行重新加载,比较耗时、耗性能。所以在页面比较多的系统中实现多页签模式的体验还是比较好的。那么在传统的layui+jq项目中,如何实现无限页签tab式打开页面呢?废话不多说,现在就开始撸代码。
首先监听菜单按钮在点击时使用layui的element去动态添加tab(增加tab的时候先删除对应已存在的tab,防止重复),并且在tab中加入iframe(高度自动撑大),iframe中的reportName是对应页面所在的文件夹名同时也是菜单按钮的id,是一一对应的关系:
var element = layui.element;
$(".report-list > ul li").on("click", function () {
//事件代理点击
var crrentTabName = $(".layui-tab.active").attr("lay-filter");
var reportName = $(this).data("id");
//点击后新增tab
element.tabDelete(crrentTabName, reportName);
element.tabAdd(crrentTabName, {
title: $(this).find(".title").text(),
content:
'<iframe id="Iframe" src="./' +
reportName +
'/index.html" width="100%" height="' +
($(".body-main").height() -
50) +
'" scrolling="no" marginheight="0" marginwidth="0"></iframe>', //支持传入html
id: reportName,
});
element.tabChange(crrentTabName, reportName);
然后是需要对左边菜单做一个选中效果(用户知道当前在哪个菜单)和一个折叠(用户可以更宽的查看内容)
使用本地存储记录当前所处的菜单,再次进入后就会默认跳转到这个菜单,如果初始进来默认第一个,这里是UserManage
完整js代码
menu.js
layui.use(["element", "layer"], function () {
var element = layui.element;
$(".report-list > ul li").on("click", function () {
//事件代理点击
var crrentTabName = $(".layui-tab.active").attr("lay-filter");
var reportName = $(this).data("id");
//点击后新增tab
element.tabDelete(crrentTabName, reportName);
element.tabAdd(crrentTabName, {
title: $(this).find(".title").text(),
content:
'<iframe id="Iframe" src="./' +
reportName +
'/index.html" width="100%" height="' +
($(".body-main").height() -
50) +
'" scrolling="no" marginheight="0" marginwidth="0"></iframe>', //支持传入html
id: reportName,
});
element.tabChange(crrentTabName, reportName);
console.log($(".body-main").height());
// $("#Iframe").height();
});
});
$(function () {
//左侧导航点击高亮
var $nav_item = $(".layui-nav-tree > .layui-nav-item");
$nav_item.click(function () {
$nav_item.removeClass("layui-this");
$(this).addClass("layui-this");
});
changeTab = function (tabid) {
//菜单选中效果
$(".layui-tab").removeClass("active");
$('[lay-filter="' + tabid + '"]').addClass("active");
sessionStorage.setItem("className", tabid);
// var ss = window.location.href.indexOf("/html/");
// var aa = window.location.href.substr(0, ss + 6);
// url = aa + url;
// document.getElementById("Iframe").src = url;
// alert($(".body-main").height());
// $(".layui-tab-content").height($(".body-main").height());
};
//菜单折叠按钮效果
$(".left-button").click(function () {
if ($(this).hasClass("layui-icon-left")) {
$(this).removeClass("layui-icon-left").addClass("layui-icon-right");
$(".body-left").hide();
$(".body-main").css("width", "100%");
} else {
$(this).removeClass("layui-icon-right").addClass("layui-icon-left");
$(".body-left").show();
$(".body-main").css("width", "calc(100% - 230px)");
}
});
window.changeUrl = function (url, className) {
console.log(className);
console.log(url);
//匹配url第一个路径字符用于在一级菜单高亮
$("#main-menu > li").removeClass("selected");
$("#main-menu > ." + url.split("/")[0] + "_1").addClass("selected");
// sessionStorage.setItem("url", url);
sessionStorage.setItem("className", className);
var ss = window.location.href.indexOf("/html/");
var aa = window.location.href.substr(0, ss + 6);
url = aa + url.split("/")[0];
console.log(url);
document.getElementById("Iframe") &&
(document.getElementById("Iframe").src =
url + "/" + className + "/index.html");
};
if (
sessionStorage.getItem("className") !== "null" &&
$("." + sessionStorage.getItem("className")).length > 0
) {//记忆上次停留菜单
$("." + sessionStorage.getItem("className")).addClass("layui-this");
if (sessionStorage.getItem("url")) {
changeUrl(
sessionStorage.getItem("url"),
sessionStorage.getItem("className")
);
}
} else {
changeUrl(sessionStorage.getItem("url"), "UserManage");
//如上次菜单不匹配则默认第一个选中
$(".layui-nav > .layui-nav-item:first-child").addClass("layui-this");
}
});
下面是html结构,使用的是layui的导航组件,右侧就默认展示一个菜单(无法关闭的列表tab)
<body>
<div class="body-left">
<div class="left-nav">
<ul class="layui-nav layui-nav-tree layui-inline" lay-filter="left-nav" style="margin-right: 10px;">
<li class="layui-nav-item workOrderTab "><a href="#" onclick="changeTab('workOrderTab')">报表1</a></li>
<li class="layui-nav-item callCenterTab"><a href="#" onclick="changeTab('callCenterTab')">报表2</a></li>
</ul>
</div>
</div>
<div class="left-button layui-icon layui-icon-left" ></div>
<div class="body-main">
<div class="layui-tab active" lay-filter="workOrderTab" lay-allowClose="true" >
<ul class="layui-tab-title">
<li class="layui-this" lay-id="default">报表</li>
</ul>
<div class="layui-tab-content">
<div class="layui-tab-item layui-show">
<div class="report-list">
<ul>
<li data-id='WorkOrderDetail'>
<div class="item" >
<div class="title">报表1</div>
<div class="desc">一个描述</div>
</div>
</li>
<li data-id='WorkOrderSource' >
<div class="item">
<div class="title">报表yyyy</div>
<div class="desc">一个描述</div>
</div>
</li>
<li data-id='WorkOrderClassify' >
<div class="item">
<div class="title">分类报表</div>
<div class="desc">一个描述</div>
</div>
</li>
</ul>
</div>
</div>
</div>
</div>
<div class="layui-tab" lay-filter="callCenterTab" lay-allowClose="true" >
<ul class="layui-tab-title">
<li class="layui-this" lay-id="default"> 报表222</li>
</ul>
<div class="layui-tab-content">
<div class="layui-tab-item layui-show">
<div class="report-list">
<ul>
<li data-id='callCenterConnectionRate'>
<div class="item" >
<div class="title">报表xxx</div>
<div class="desc">展示不同的报表</div>
</div>
</li>
<li data-id='CallRecordsData'>
<div class="item" >
<div class="title">记录详情</div>
<div class="desc">展示不同条件下的报表</div>
</div>
</li>
<li data-id='AfterSaleTimeRate'>
<div class="item" >
<div class="title">状态</div>
<div class="desc">报表描述</div>
</div>
</li>
</ul>
</div>
</div>
</div>
</div>
</body>
css部分:
body{
padding: 0;
}
.out{
display: none;
}
.body-main{
width: 100%;
height: 100%;
}
.body-main iframe {
background-color: #fff;
border: 0px;
}
.left-nav{
background: #fff;
}
.layui-nav .layui-nav-item a{
background: transparent;
color: #3b3a3a;
}
.layui-nav{
background: #fbfbfb00;
}
.layui-nav-tree .layui-nav-item a:hover{
background-color: #297acc;
}
.layui-nav-tree .layui-this a{
background-color: #297acc !important;
color:#fff ;
}
.body-left{
width: 200px;
overflow-x: hidden;
border-right: 10px solid #eaf4ff;
}
.body-main{
width: calc(100% - 230px);
float: left;
}
.layui-tab{
display: none;
}
.layui-tab.active{
display: block;
}
.headTab.layui-tab-title .layui-this {
color: #3193f5;
}
.layui-tab {
margin: 0;
}
.left-button {
text-align: center;
left:180px;
top: calc(50% - 40px);
color: #fff;
width: 20px;
height: 40px;
background: rgba(90, 169, 247, .9);
border-radius: 4px 0 0 4px;
line-height: 40px;
position: absolute;
cursor: pointer;
z-index: 99;
}
.left-button.layui-icon-right{
left: 0;
border-radius: 0px 4px 4px 0px;
}
.menu-authority-control{
display: none;
}
.layui-tab-title>li:first-child .layui-tab-close {
display: none;
}
.report-list{
padding: 20px;
}
.report-list > ul > li{
cursor: pointer;
margin-bottom: 30px;
}
.report-list ul li:hover div .title {
color: rgb(49, 147, 245);
}
.item >.title{
font-size: 16px;
margin-bottom: 6px;
border-bottom: 1px solid #e6e6e6;
display: inline-block;
padding-bottom: 2px;
}
.item >.desc{
font-size: 12px;
line-height: 20px;
}
.layui-tab-content{
overflow-y: auto;
}