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 相关文章推荐
为数据添加append,remove功能
Oct 03 Javascript
asp(javascript)全角半角转换代码 dbc2sbc
Aug 06 Javascript
JavaScript 联动的无限级封装类,数据采用非Ajax方式,随意添加联动
Jun 29 Javascript
url参数中有+、空格、=、%、&amp;、#等特殊符号的问题解决
May 15 Javascript
jquery.hotkeys监听键盘按下事件keydown插件
May 11 Javascript
JQuery中使用.each()遍历元素学习笔记
Nov 08 Javascript
JQuery的ON()方法支持的所有事件罗列
Feb 28 Javascript
JS实现仿腾讯微博无刷新删除微博效果代码
Oct 16 Javascript
bootstrap-wysiwyg结合ajax实现图片上传实时刷新功能
May 27 Javascript
JS 滚动事件window.onscroll与position:fixed写兼容IE6的回到顶部组件
Oct 10 Javascript
vue mint-ui学习笔记之picker的使用
Oct 11 Javascript
jQuery实现数字华容道小游戏(实例代码)
Jan 16 jQuery
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
JavaScript 设计模式之组合模式解析
2010/04/09 Javascript
Js切换功能的简单方法
2010/11/23 Javascript
Jquery 获取checkbox的checked问题
2011/11/16 Javascript
运算符&amp;&amp;的三个不同层次
2013/04/07 Javascript
js中的异常处理try...catch使用介绍
2013/09/21 Javascript
判断js中各种数据的类型方法之typeof与0bject.prototype.toString讲解
2013/11/07 Javascript
js 显示base64编码的二进制流网页图片
2014/04/04 Javascript
JavaScript Math.ceil 方法(对数值向上取整)
2015/01/09 Javascript
JavaScript实现的简单幂函数实例
2015/04/17 Javascript
jQuery实现下拉框选择图片功能实例
2015/08/08 Javascript
Angular.js中$apply()和$digest()的深入理解
2016/10/13 Javascript
微信小程序 自己制作小组件实例详解
2016/12/22 Javascript
js处理层级数据结构的方法小结
2017/01/17 Javascript
vue 子组件向父组件传值方法
2018/02/26 Javascript
vue中使用cropperjs的方法
2018/03/01 Javascript
vue基于better-scroll实现左右联动滑动页面
2020/06/30 Javascript
python Opencv将图片转为字符画
2021/02/19 Python
python 字典 按key值大小 倒序取值的实例
2018/07/06 Python
pandas 选取行和列数据的方法详解
2019/08/08 Python
python基于pdfminer库提取pdf文字代码实例
2019/08/15 Python
在Tensorflow中实现梯度下降法更新参数值
2020/01/23 Python
记一次pyinstaller打包pygame项目为exe的过程(带图片)
2020/03/02 Python
移动端HTML5开发神器之vconsole详解
2020/12/15 HTML / CSS
英国拳击装备购物网站:RDX Sports
2018/01/23 全球购物
餐厅考勤管理制度
2014/01/28 职场文书
普通简短的个人自我评价
2014/02/15 职场文书
公司新年寄语
2014/04/04 职场文书
祖国在我心中的演讲稿
2014/05/04 职场文书
奉献家乡演讲稿
2014/09/13 职场文书
无刑事犯罪记录证明
2014/09/18 职场文书
行政撤诉申请书
2015/05/18 职场文书
2016幼儿园教师年度考核评语
2015/12/01 职场文书
《亲亲我的妈妈》观后感(3篇)
2019/09/26 职场文书
简单介绍 http请求响应参数、无连接无状态、MIME、状态码、端口、telnet、curl
2021/03/31 HTML / CSS
Nginx 502 bad gateway错误解决的九种方案及原因
2022/08/14 Servers
CSS中calc(100%-100px)不加空格不生效
2023/05/07 HTML / CSS