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 相关文章推荐
js 获取class的元素的方法 以及创建方法getElementsByClassName
Mar 11 Javascript
Javascript弹出窗口的各种方法总结
Nov 11 Javascript
纯JavaScript基于notie.js插件实现消息提示特效
Jan 18 Javascript
个人网站留言页面(前端jQuery编写、后台php读写MySQL)
May 03 Javascript
浅谈JSON.stringify()和JOSN.parse()方法的不同
Aug 29 Javascript
简单理解vue中track-by属性
Oct 26 Javascript
AngularJS辅助库browserTrigger用法示例
Nov 03 Javascript
Vue报错:Uncaught TypeError: Cannot assign to read only property’exports‘ of object’#‘的解决方法
Jun 17 Javascript
layer弹出的iframe层在执行完毕后关闭当前弹出层的方法
Aug 17 Javascript
基于Taro的微信小程序模板消息-获取formId功能模块封装实践
Jul 15 Javascript
javascript删除数组元素的七个方法示例
Sep 09 Javascript
vue-cli设置css不生效的解决方法
Feb 07 Javascript
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
用PHP连接MySQL代码的参数说明
2008/06/07 PHP
php面向对象的方法重载两种版本比较
2008/09/08 PHP
使用PHP获取网络文件的实现代码
2010/01/01 PHP
php判断是否为ajax请求的方法
2016/11/29 PHP
PHP基于回溯算法解决n皇后问题的方法示例
2017/11/07 PHP
图片连续滚动代码[兼容IE/firefox]
2009/06/11 Javascript
javascript常见操作汇总
2014/09/03 Javascript
javascript实现根据身份证号读取相关信息
2014/12/17 Javascript
JQuery右键菜单插件ContextMenu使用指南
2014/12/19 Javascript
浅谈javascript中replace()方法
2015/11/10 Javascript
Jquery实现$.fn.extend和$.extend函数
2016/04/14 Javascript
Javascript 正则表达式校验数字的简单实例
2016/11/02 Javascript
javascript基本数据类型及类型检测常用方法小结
2016/12/14 Javascript
vue中appear的用法
2017/08/17 Javascript
nodejs中密码加密处理操作详解
2018/03/20 NodeJs
解决Vue在Tomcat8下部署页面不加载的问题
2019/11/12 Javascript
Python操作MySQL数据库的三种方法总结
2018/01/30 Python
用Python一键搭建Http服务器的方法
2018/06/01 Python
对Python中DataFrame选择某列值为XX的行实例详解
2019/01/29 Python
Python实现多态、协议和鸭子类型的代码详解
2019/05/05 Python
简单了解python关系(比较)运算符
2019/07/08 Python
在TensorFlow中屏蔽warning的方式
2020/02/04 Python
Python3实现监控新型冠状病毒肺炎疫情的示例代码
2020/02/13 Python
用python介绍4种常用的单链表翻转的方法小结
2020/02/24 Python
Python中sys模块功能与用法实例详解
2020/02/26 Python
浅谈Python中的模块
2020/06/10 Python
2020年10款优秀的Python第三方库,看看有你中意的吗?
2021/01/12 Python
html5 css3实例教程 一款html5和css3实现的小机器人走路动画
2014/10/20 HTML / CSS
Kenneth Cole官网:纽约时尚优雅品牌
2016/11/14 全球购物
阿迪达斯芬兰官方网站:adidas芬兰
2017/01/30 全球购物
英国在线玫瑰专家:InterRose
2019/12/01 全球购物
Ibatis如何使用动态表名
2015/07/12 面试题
音乐教育专业自荐信
2014/09/18 职场文书
教师四风自我剖析材料
2014/09/30 职场文书
明星邀请函
2015/02/02 职场文书
Nginx URL重写rewrite机制原理及使用实例
2021/04/01 Servers