layui添加动态菜单与选项卡


Posted in Javascript onJuly 26, 2019

本文实例为大家分享了layui添加动态菜单与选项卡的具体代码,供大家参考,具体内容如下

HTML

<!DOCTYPE html>
<html>
 <head>
 <meta charset="utf-8">
 <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
 <title>Layui</title>
 <link rel="stylesheet" href="js/css/layui.css" media="all">
 </head>
 <body>
 <div class="layui-side layui-bg-black">
 <div class="layui-side-scroll">
 <!-- 左侧导航区域(可配合layui已有的垂直导航) -->
 <ul class="layui-nav layui-nav-tree" lay-filter="test" id="memus"></ul>
 </div>
 </div>
 <div class="layui-body">
 <!-- 动态选项卡 -->
 <div id="tabzu" class="layui-tab layui-tab-card layui-tab-brief" lay-filter="tabDemo" lay-allowclose="true">
 <ul class="layui-tab-title"></ul>
 <div class="layui-tab-content"></div>
 </div>
 </div>
 <script src="js/layui.all.js" charset="utf-8"></script>
 <script type="text/javascript" src="js/index.js" ></script>
 </body>
 
</html>

index.js

layui.use('element', function() {
 function checkLastItem(arr, i) {
 return arr.length == (i + 1);
 }
 
 function getAhtml(obj){
 return "<a href=\"javascript:;\" οnclick=\"addTab('" + obj.name + "','" + obj.url + "')\" >" + obj.name + "</a>";
 }
 //动态菜单
 layui.jquery.ajax({
 url: "http://127.0.0.1:18000/sys/menus",
 method: 'POST',
 success: function(res) {
 var html = "";
 for(var i = 0; i < res.length; i++) {
 var strli = "<li class=\"layui-nav-item lay-unselect \" >";
 if (res[i].url =='#'){
 strli = strli + "<a href=\"javascript:;\">" + res[i].name + "</a>";
 console.log(res[i].name)
 }else{
 strli = strli + getAhtml(res[i]);
 }
 if(res[i].pId == "0" && !checkLastItem(res, i) && res[i + 1].pId != "0") {
 strli = strli + "<dl class=\"layui-nav-child\" >";
 for(; !checkLastItem(res, i) && res[i + 1].pId != "0"; i++) {
 strli = strli + "<dd>"+getAhtml(res[i+1])+"</dd>";
 }
 strli = strli + "</dl>";
 }
 strli = strli + "</li>";
 html = html + strli;
 }
 layui.jquery("#memus").html(html);
 layui.element.init(); //一定初始化一次
 }
 })
});
 
//添加选项卡
function addTab(name, url) {
 if(layui.jquery(".layui-tab-title li[lay-id='" + name + "']").length > 0) {
 //选项卡已经存在
 layui.element.tabChange('tabDemo', name);
 layer.msg('切换-' + name)
 } else {
 //动态控制iframe高度
 var tabheight = layui.jquery(window).height() - 95;
 contentTxt = '<iframe src="' + url + '" scrolling="no" width="100%" height="' + (tabheight) + 'PX"></iframe>';
 //新增一个Tab项
 layui.element.tabAdd('tabDemo', {
 title: name,
 content: contentTxt,
 id: name
 })
 //切换刷新
 layui.element.tabChange('tabDemo', name)
 layer.msg('新增-' + name)
 }
}

菜单JSON

[
 {
 "name": "首页",
 "url": "shouye.html",
 "id": "1",
 "pId": "0"
 },
 {
 "name": "数据库",
 "url": "#",
 "id": "1",
 "pId": "0"
 },
 {
 "name": "MYSQL",
 "url": "mysql.html",
 "id": "2",
 "pId": "1"
 },
 {
 "name": "ORACLE",
 "url": "oracle.html",
 "id": "3",
 "pId": "1"
 },
 {
 "name": "开发语言",
 "url": "#",
 "id": "4",
 "pId": "0"
 },
 {
 "name": "JAVA",
 "url": "java.html",
 "id": "5",
 "pId": "4"
 },
 {
 "name": "Python",
 "url": "python.html",
 "id": "6",
 "pId": "4"
 }
]

效果截图:

layui添加动态菜单与选项卡

如果大家还想深入学习,可以点击两个精彩的专题:javascript选项卡操作方法汇总 jquery选项卡操作方法汇总

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

Javascript 相关文章推荐
Jquery增加鼠标中间功能mousewheel的实例代码
Sep 05 Javascript
escape编码与unescape解码汉字出现乱码的解决方法
Jul 02 Javascript
jquery实现简单手风琴菜单效果实例
Jun 13 Javascript
jQuery zclip插件实现跨浏览器复制功能
Nov 02 Javascript
AngularJS的ng-repeat指令与scope继承关系实例详解
Jan 21 Javascript
js前端日历控件(悬浮、拖拽、自由变形)
Mar 02 Javascript
vue-video-player 通过自定义按钮组件实现全屏切换效果【推荐】
Aug 29 Javascript
vue-cli项目代理proxyTable配置exclude的方法
Sep 20 Javascript
vue2 设置router-view默认路径的实例
Sep 20 Javascript
浅谈KOA2 Restful方式路由初探
Mar 14 Javascript
vue-cli3中vue.config.js配置教程详解
May 29 Javascript
vue+element实现动态加载表单
Dec 13 Vue.js
layer设置maxWidth及maxHeight解决方案
Jul 26 #Javascript
javascript中的闭包概念与用法实践分析
Jul 26 #Javascript
layui自定义插件citySelect实现省市区三级联动选择
Jul 26 #Javascript
微信小程序自定义头部导航栏和导航栏背景图片 navigationStyle问题
Jul 26 #Javascript
jQuery-Citys省市区三级菜单联动插件使用详解
Jul 26 #jQuery
微信小程序—setTimeOut定时器的问题及解决
Jul 26 #Javascript
layUI实现三级导航菜单效果
Jul 26 #Javascript
You might like
第十四节 命名空间 [14]
2006/10/09 PHP
php smarty模版引擎中的缓存应用
2009/12/02 PHP
10条PHP高级技巧[修正版]
2011/08/02 PHP
php使用递归函数实现数字累加的方法
2015/03/16 PHP
PHP下载文件的函数实例代码
2016/05/18 PHP
PHP进阶学习之垃圾回收机制详解
2019/06/18 PHP
yii框架结合charjs实现统计30天数据的方法
2020/04/04 PHP
URI、URL和URN之间的区别与联系
2006/12/20 Javascript
基于jQuery实现点击同时更改两个iframe的网址
2010/07/01 Javascript
jQuery UI Datepicker length为空或不是对象错误的解决方法
2010/12/19 Javascript
Extjs中TabPane如何嵌套在其他网页中实现思路及代码
2013/01/27 Javascript
js实现通用的微信分享组件示例
2014/03/10 Javascript
jquery 页眉单行信息滚动显示实现思路及代码
2014/06/26 Javascript
JS实现的不规则TAB选项卡效果代码
2015/09/18 Javascript
温习Javascript基础语法之词法结构
2016/05/31 Javascript
jQuery中$.ajax()方法参数解析
2016/10/22 Javascript
js导出excel文件的简洁方法(推荐)
2016/11/02 Javascript
Vue导出json数据到Excel电子表格的示例
2017/12/04 Javascript
Vue 递归多级菜单的实例代码
2019/05/05 Javascript
VUE项目axios请求头更改Content-Type操作
2020/07/24 Javascript
python实现爬虫统计学校BBS男女比例之多线程爬虫(二)
2015/12/31 Python
python中WSGI是什么,Python应用WSGI详解
2017/11/24 Python
Python面向对象程序设计中类的定义、实例化、封装及私有变量/方法详解
2019/02/28 Python
关于多元线性回归分析——Python&amp;SPSS
2020/02/24 Python
Python paramiko使用方法代码汇总
2020/11/20 Python
python re.match()用法相关示例
2021/01/27 Python
基于HTML5 Canvas的3D动态Chart图表的示例
2017/11/02 HTML / CSS
莱德杯高尔夫欧洲官方商店:Ryder Cup Shop
2019/08/14 全球购物
摄影实习自我鉴定
2013/09/20 职场文书
北体毕业生求职信
2014/02/28 职场文书
校园活动宣传方案
2014/03/28 职场文书
乡镇三项教育实施方案
2014/03/30 职场文书
工伤认定行政答辩状
2015/05/22 职场文书
中学后勤工作总结2015
2015/07/22 职场文书
经销商会议开幕词
2016/03/04 职场文书
医生行业员工的辞职信
2019/06/24 职场文书