当前页层级结构
parent
c95b699e13
commit
93854b6082
|
|
@ -99,7 +99,7 @@ layui.define(['table', 'jquery', 'element', 'form', 'pearTab', 'pearMenu', 'pear
|
|||
// 选 项 卡 初 始 API 文 档
|
||||
bodyFrame = pearFrame.render({
|
||||
elem: 'content',
|
||||
title: '首 页',
|
||||
title: '工作空间 / 首页',
|
||||
url: option.index,
|
||||
width: '100%',
|
||||
height: '100%'
|
||||
|
|
|
|||
|
|
@ -1,472 +1,542 @@
|
|||
layui.define(['table', 'jquery', 'element'], function (exports) {
|
||||
"use strict";
|
||||
layui.define(['table', 'jquery', 'element'], function(exports) {
|
||||
"use strict";
|
||||
|
||||
var MOD_NAME = 'pearMenu',
|
||||
$ = layui.jquery,
|
||||
var MOD_NAME = 'pearMenu',
|
||||
$ = layui.jquery,
|
||||
element = layui.element;
|
||||
|
||||
var pearMenu = function (opt) {
|
||||
this.option = opt;
|
||||
};
|
||||
|
||||
pearMenu.prototype.render = function (opt) {
|
||||
//默认配置值
|
||||
var pearMenu = function(opt) {
|
||||
this.option = opt;
|
||||
};
|
||||
|
||||
pearMenu.prototype.render = function(opt) {
|
||||
//默认配置值
|
||||
var option = {
|
||||
elem:opt.elem,
|
||||
async:opt.async ? opt.async : false,
|
||||
parseData:opt.parseData,
|
||||
url:opt.url,
|
||||
defaultOpen:opt.defaultOpen,
|
||||
control:opt.control,
|
||||
defaultMenu:opt.defaultMenu,
|
||||
accordion:opt.accordion,
|
||||
height:opt.height,
|
||||
theme:opt.theme,
|
||||
data:opt.data ? opt.data:[],
|
||||
change: opt.change ? opt.change:function(){console.log("切换") },
|
||||
done:opt.done ? opt.done: function(){ console.log("菜单渲染成功");}
|
||||
elem: opt.elem,
|
||||
async: opt.async ? opt.async : false,
|
||||
parseData: opt.parseData,
|
||||
url: opt.url,
|
||||
defaultOpen: opt.defaultOpen,
|
||||
control: opt.control,
|
||||
defaultMenu: opt.defaultMenu,
|
||||
accordion: opt.accordion,
|
||||
height: opt.height,
|
||||
theme: opt.theme,
|
||||
data: opt.data ? opt.data : [],
|
||||
change: opt.change ? opt.change : function() {
|
||||
console.log("切换")
|
||||
},
|
||||
done: opt.done ? opt.done : function() {
|
||||
console.log("菜单渲染成功");
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
// 根 据 请 求 方 式 获 取 数 据
|
||||
if(option.async){
|
||||
option.data = getData(option.url);
|
||||
if(option.parseData!=false){
|
||||
option.parseData(option.data);
|
||||
}
|
||||
if (option.async) {
|
||||
option.data = getData(option.url);
|
||||
if (option.parseData != false) {
|
||||
option.parseData(option.data);
|
||||
}
|
||||
}
|
||||
|
||||
if(option.control!=false){
|
||||
|
||||
|
||||
if (option.control != false) {
|
||||
|
||||
createMenuAndControl(option);
|
||||
|
||||
}else{
|
||||
|
||||
} else {
|
||||
createMenu(option);
|
||||
}
|
||||
|
||||
|
||||
// 渲 染 菜 单 结 束 并 完 成
|
||||
|
||||
|
||||
// 渲 染 菜 单 结 束 并 完 成
|
||||
element.init();
|
||||
|
||||
|
||||
downShow(option);
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
option.done();
|
||||
return new pearMenu(option);
|
||||
}
|
||||
|
||||
|
||||
/** 监听事件赋值 */
|
||||
pearMenu.prototype.click = function(clickEvent){
|
||||
|
||||
var _this = this;
|
||||
$("#"+_this.option.elem+" .site-demo-active").parent().click(function(){
|
||||
var dom = $(this).children(".site-demo-active");
|
||||
var data = {menuId:dom.attr("menu-id"),menuTitle:dom.attr("menu-title"),menuIcon:dom.attr("menu-icon"),menuUrl:dom.attr("menu-url")};
|
||||
clickEvent(dom,data);
|
||||
});
|
||||
|
||||
}
|
||||
|
||||
|
||||
pearMenu.prototype.skin = function(skin){
|
||||
|
||||
var menu = $(".pear-nav-tree[lay-filter='"+this.option.elem+"']").parent();
|
||||
|
||||
menu.removeClass("dark-theme");
|
||||
|
||||
|
||||
/** 监听事件赋值 */
|
||||
pearMenu.prototype.click = function(clickEvent) {
|
||||
|
||||
var _this = this;
|
||||
$("#" + _this.option.elem + " .site-demo-active").parent().click(function() {
|
||||
var dom = $(this).children(".site-demo-active");
|
||||
var data = {
|
||||
menuId: dom.attr("menu-id"),
|
||||
menuTitle: dom.attr("menu-title"),
|
||||
menuIcon: dom.attr("menu-icon"),
|
||||
menuUrl: dom.attr("menu-url")
|
||||
};
|
||||
|
||||
var doms = hash(dom);
|
||||
|
||||
if (doms.text() != '') {
|
||||
data['menuTitle'] = doms.find("span").text() + " / " + data['menuTitle'];
|
||||
|
||||
}
|
||||
var domss = hash(doms);
|
||||
|
||||
if (domss.text() != '') {
|
||||
|
||||
data['menuTitle'] = domss.find("span").text() + " / " + data['menuTitle'];
|
||||
|
||||
}
|
||||
|
||||
var domsss = hash(domss);
|
||||
|
||||
if (domsss.text() != '') {
|
||||
|
||||
data['menuTitle'] = domsss.find("span").text() + " / " + data['menuTitle'];
|
||||
|
||||
}
|
||||
|
||||
clickEvent(dom, data);
|
||||
});
|
||||
|
||||
}
|
||||
|
||||
function hash(dom) {
|
||||
|
||||
return dom.parent().parent().prev();
|
||||
}
|
||||
|
||||
|
||||
pearMenu.prototype.skin = function(skin) {
|
||||
|
||||
var menu = $(".pear-nav-tree[lay-filter='" + this.option.elem + "']").parent();
|
||||
|
||||
menu.removeClass("dark-theme");
|
||||
menu.removeClass("light-theme");
|
||||
|
||||
|
||||
menu.addClass(skin);
|
||||
}
|
||||
|
||||
|
||||
pearMenu.prototype.selectItem = function(pearId){
|
||||
|
||||
if(this.option.control != false){
|
||||
|
||||
$("#"+this.option.elem+" a[menu-id='"+pearId+"']").parents(".layui-side-scroll ").find("ul").css({display:"none"});
|
||||
|
||||
$("#"+this.option.elem+" a[menu-id='"+pearId+"']").parents(".layui-side-scroll ").find(".layui-this").removeClass("layui-this");
|
||||
|
||||
$("#"+this.option.elem+" a[menu-id='"+pearId+"']").parents("ul").css({display:"block"});
|
||||
|
||||
var controlId = $("#"+this.option.elem+" a[menu-id='"+pearId+"']").parents("ul").attr("pear-id");
|
||||
|
||||
$("#"+this.option.control).find(".layui-this").removeClass("layui-this");
|
||||
|
||||
$("#"+this.option.control).find("[pear-id='"+controlId+"']").addClass("layui-this");
|
||||
|
||||
|
||||
pearMenu.prototype.selectItem = function(pearId) {
|
||||
|
||||
if (this.option.control != false) {
|
||||
|
||||
$("#" + this.option.elem + " a[menu-id='" + pearId + "']").parents(".layui-side-scroll ").find("ul").css({
|
||||
display: "none"
|
||||
});
|
||||
|
||||
$("#" + this.option.elem + " a[menu-id='" + pearId + "']").parents(".layui-side-scroll ").find(".layui-this").removeClass(
|
||||
"layui-this");
|
||||
|
||||
$("#" + this.option.elem + " a[menu-id='" + pearId + "']").parents("ul").css({
|
||||
display: "block"
|
||||
});
|
||||
|
||||
var controlId = $("#" + this.option.elem + " a[menu-id='" + pearId + "']").parents("ul").attr("pear-id");
|
||||
|
||||
$("#" + this.option.control).find(".layui-this").removeClass("layui-this");
|
||||
|
||||
$("#" + this.option.control).find("[pear-id='" + controlId + "']").addClass("layui-this");
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
// 根 据 菜 单 Id 选 中 菜 单 项 目
|
||||
|
||||
|
||||
$("#"+this.option.elem+" a[menu-id='"+pearId+"']").parents(".pear-nav-tree").find(".layui-nav-itemed").removeClass("layui-nav-itemed");
|
||||
|
||||
$("#"+this.option.elem+" a[menu-id='"+pearId+"']").parents(".pear-nav-tree").find(".layui-this").removeClass("layui-this");
|
||||
|
||||
|
||||
|
||||
$("#" + this.option.elem + " a[menu-id='" + pearId + "']").parents(".pear-nav-tree").find(".layui-nav-itemed").removeClass(
|
||||
"layui-nav-itemed");
|
||||
|
||||
$("#" + this.option.elem + " a[menu-id='" + pearId + "']").parents(".pear-nav-tree").find(".layui-this").removeClass(
|
||||
"layui-this");
|
||||
|
||||
// 通 过 动 画 打 开 当 前 菜 单 项 layui-nav-child
|
||||
|
||||
if(!$("#"+this.option.elem).is(".pear-nav-mini")){
|
||||
|
||||
$("#"+this.option.elem+" a[menu-id='"+pearId+"']").parents(".layui-nav-item").addClass("layui-nav-itemed");
|
||||
|
||||
$("#"+this.option.elem+" a[menu-id='"+pearId+"']").parents("dd").addClass("layui-nav-itemed");
|
||||
|
||||
|
||||
if (!$("#" + this.option.elem).is(".pear-nav-mini")) {
|
||||
|
||||
$("#" + this.option.elem + " a[menu-id='" + pearId + "']").parents(".layui-nav-item").addClass("layui-nav-itemed");
|
||||
|
||||
$("#" + this.option.elem + " a[menu-id='" + pearId + "']").parents("dd").addClass("layui-nav-itemed");
|
||||
|
||||
}
|
||||
|
||||
$("#"+this.option.elem+" a[menu-id='"+pearId+"']").parent().addClass("layui-this");
|
||||
|
||||
|
||||
|
||||
$("#" + this.option.elem + " a[menu-id='" + pearId + "']").parent().addClass("layui-this");
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
var activeMenus;
|
||||
|
||||
pearMenu.prototype.collaspe = function(time){
|
||||
|
||||
|
||||
pearMenu.prototype.collaspe = function(time) {
|
||||
|
||||
var elem = this.option.elem;
|
||||
|
||||
|
||||
var config = this.option;
|
||||
|
||||
if($("#"+this.option.elem).is(".pear-nav-mini")){
|
||||
|
||||
$.each(activeMenus,function(i,item){
|
||||
$("#"+elem+" a[menu-id='" + $(this).attr("menu-id") + "']").parent().addClass("layui-nav-itemed");
|
||||
|
||||
if ($("#" + this.option.elem).is(".pear-nav-mini")) {
|
||||
|
||||
$.each(activeMenus, function(i, item) {
|
||||
$("#" + elem + " a[menu-id='" + $(this).attr("menu-id") + "']").parent().addClass("layui-nav-itemed");
|
||||
})
|
||||
|
||||
$("#"+this.option.elem).removeClass("pear-nav-mini");
|
||||
|
||||
$("#"+this.option.elem).animate({
|
||||
width: "220px"
|
||||
},150);
|
||||
|
||||
isHoverMenu(false,config);
|
||||
|
||||
}else{
|
||||
|
||||
activeMenus = $("#"+this.option.elem).find(".layui-nav-itemed>a");
|
||||
$("#"+this.option.elem).find(".layui-nav-itemed").removeClass("layui-nav-itemed");
|
||||
|
||||
$("#"+this.option.elem).addClass("pear-nav-mini");
|
||||
|
||||
$("#"+this.option.elem).animate({
|
||||
width: "60px"
|
||||
},400);
|
||||
isHoverMenu(true,config);
|
||||
|
||||
|
||||
$("#" + this.option.elem).removeClass("pear-nav-mini");
|
||||
|
||||
$("#" + this.option.elem).animate({
|
||||
width: "220px"
|
||||
}, 150);
|
||||
|
||||
isHoverMenu(false, config);
|
||||
|
||||
} else {
|
||||
|
||||
activeMenus = $("#" + this.option.elem).find(".layui-nav-itemed>a");
|
||||
$("#" + this.option.elem).find(".layui-nav-itemed").removeClass("layui-nav-itemed");
|
||||
|
||||
$("#" + this.option.elem).addClass("pear-nav-mini");
|
||||
|
||||
$("#" + this.option.elem).animate({
|
||||
width: "60px"
|
||||
}, 400);
|
||||
isHoverMenu(true, config);
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
/** 同 步 请 求 获 取 数 据 */
|
||||
function getData(url){
|
||||
|
||||
|
||||
/** 同 步 请 求 获 取 数 据 */
|
||||
function getData(url) {
|
||||
|
||||
$.ajaxSettings.async = false;
|
||||
var data = null;
|
||||
|
||||
|
||||
$.get(url, function(result) {
|
||||
data = result;
|
||||
});
|
||||
|
||||
|
||||
$.ajaxSettings.async = true;
|
||||
return data;
|
||||
}
|
||||
|
||||
|
||||
function createMenu(option){
|
||||
// 声 明 头 部
|
||||
var menuHtml = '<ul lay-filter="'+option.elem+'" class="layui-nav arrow pear-menu layui-nav-tree pear-nav-tree">'
|
||||
// 开 启 同 步 操 作
|
||||
$.each(option.data, function(i, item) {
|
||||
// 创 建 每 一 个 菜 单 项
|
||||
|
||||
|
||||
var content = '<li class="layui-nav-item" >';
|
||||
|
||||
if(i==option.defaultOpen && option.defaultOpen!=false){
|
||||
content = '<li class="layui-nav-item layui-nav-itemed" >';
|
||||
}
|
||||
|
||||
var href = "javascript:;";
|
||||
var target = "";
|
||||
var calss = "site-demo-active"
|
||||
|
||||
if(item.openType == "_blank" && item.type == 1){
|
||||
href = item.href;
|
||||
target = "target='_blank'";
|
||||
calss = "";
|
||||
}
|
||||
|
||||
// 判 断 菜 单 类 型 0 是 不可跳转的目录 1 是 可 点 击 跳 转 的 菜 单
|
||||
if (item.type == 0) {
|
||||
// 创 建 目 录 结 构
|
||||
content += '<a href="javascript:;" menu-type="'+item.type+'" menu-id="'+item.id+'" href="'+ href +'" '+ target +'><i class="' + item.icon + '"></i><span>' + item.title +
|
||||
'</span></a>';
|
||||
} else if (item.type == 1) {
|
||||
// 创 建 菜 单 结 构
|
||||
content += '<a class="'+calss+'" menu-type="'+item.type+'" menu-url="' + item.href + '" menu-id="' + item.id +
|
||||
'" menu-title="' + item.title + '" href="'+href+'" '+ target +'><i class="' + item.icon +
|
||||
'"></i><span>' + item.title + '</span></a>';
|
||||
}
|
||||
// 调 用 递 归 方 法 加 载 无 限 层 级 的 子 菜 单
|
||||
content += loadchild(item);
|
||||
// 结 束 一 个 根 菜 单 项
|
||||
content += '</li>';
|
||||
menuHtml += content;
|
||||
|
||||
});
|
||||
// 结 束 菜 单 结 构 的 初 始 化
|
||||
menuHtml += "</ul>";
|
||||
// 将 菜 单 拼 接 到 初 始 化 容 器 中
|
||||
|
||||
$("#"+option.elem).html(menuHtml);
|
||||
|
||||
}
|
||||
|
||||
|
||||
function createMenuAndControl(option){
|
||||
|
||||
var control = '<ul class="layui-nav pear-nav-control">';
|
||||
|
||||
function createMenu(option) {
|
||||
// 声 明 头 部
|
||||
var menu = '<div class="layui-side-scroll '+option.theme+'">'
|
||||
var menuHtml = '<ul lay-filter="' + option.elem +
|
||||
'" class="layui-nav arrow pear-menu layui-nav-tree pear-nav-tree">'
|
||||
// 开 启 同 步 操 作
|
||||
|
||||
var index = 0;
|
||||
|
||||
$.each(option.data, function(i, item) {
|
||||
|
||||
var menuItem = '';
|
||||
|
||||
var controlItem = '';
|
||||
|
||||
|
||||
if(index === option.defaultMenu){
|
||||
|
||||
controlItem = '<li pear-href="'+item.href+'" pear-title="'+item.title+'" pear-id="'+item.id+'" class="layui-this layui-nav-item"><a href="#">'+item.title+'</a></li>';
|
||||
|
||||
menuItem = '<ul pear-id="'+item.id+'" lay-filter="'+option.elem+'" class="layui-nav arrow layui-nav-tree pear-nav-tree">';
|
||||
|
||||
}else{
|
||||
|
||||
|
||||
controlItem = '<li pear-href="'+item.href+'" pear-title="'+item.title+'" pear-id="'+item.id+'" class="layui-nav-item"><a href="#">'+item.title+'</a></li>';
|
||||
|
||||
menuItem = '<ul style="display:none" pear-id="'+item.id+'" lay-filter="'+option.elem+'" class="layui-nav arrow layui-nav-tree pear-nav-tree">';
|
||||
|
||||
// 创 建 每 一 个 菜 单 项
|
||||
|
||||
|
||||
var content = '<li class="layui-nav-item" >';
|
||||
|
||||
if (i == option.defaultOpen && option.defaultOpen != false) {
|
||||
content = '<li class="layui-nav-item layui-nav-itemed" >';
|
||||
}
|
||||
|
||||
index ++;
|
||||
|
||||
$.each(item.children,function(i,note){
|
||||
|
||||
|
||||
var href = "javascript:;";
|
||||
var target = "";
|
||||
var calss = "site-demo-active"
|
||||
|
||||
if (item.openType == "_blank" && item.type == 1) {
|
||||
href = item.href;
|
||||
target = "target='_blank'";
|
||||
calss = "";
|
||||
}
|
||||
|
||||
// 判 断 菜 单 类 型 0 是 不可跳转的目录 1 是 可 点 击 跳 转 的 菜 单
|
||||
if (item.type == 0) {
|
||||
// 创 建 目 录 结 构
|
||||
content += '<a href="javascript:;" menu-type="' + item.type + '" menu-id="' + item.id + '" href="' + href +
|
||||
'" ' + target + '><i class="' + item.icon + '"></i><span>' + item.title +
|
||||
'</span></a>';
|
||||
} else if (item.type == 1) {
|
||||
// 创 建 菜 单 结 构
|
||||
content += '<a class="' + calss + '" menu-type="' + item.type + '" menu-url="' + item.href + '" menu-id="' +
|
||||
item.id +
|
||||
'" menu-title="' + item.title + '" href="' + href + '" ' + target + '><i class="' + item.icon +
|
||||
'"></i><span>' + item.title + '</span></a>';
|
||||
}
|
||||
// 调 用 递 归 方 法 加 载 无 限 层 级 的 子 菜 单
|
||||
content += loadchild(item);
|
||||
// 结 束 一 个 根 菜 单 项
|
||||
content += '</li>';
|
||||
menuHtml += content;
|
||||
|
||||
});
|
||||
// 结 束 菜 单 结 构 的 初 始 化
|
||||
menuHtml += "</ul>";
|
||||
// 将 菜 单 拼 接 到 初 始 化 容 器 中
|
||||
|
||||
$("#" + option.elem).html(menuHtml);
|
||||
|
||||
}
|
||||
|
||||
|
||||
function createMenuAndControl(option) {
|
||||
|
||||
var control = '<ul class="layui-nav pear-nav-control">';
|
||||
// 声 明 头 部
|
||||
var menu = '<div class="layui-side-scroll ' + option.theme + '">'
|
||||
// 开 启 同 步 操 作
|
||||
|
||||
var index = 0;
|
||||
|
||||
$.each(option.data, function(i, item) {
|
||||
|
||||
var menuItem = '';
|
||||
|
||||
var controlItem = '';
|
||||
|
||||
|
||||
if (index === option.defaultMenu) {
|
||||
|
||||
controlItem = '<li pear-href="' + item.href + '" pear-title="' + item.title + '" pear-id="' + item.id +
|
||||
'" class="layui-this layui-nav-item"><a href="#">' + item.title + '</a></li>';
|
||||
|
||||
menuItem = '<ul pear-id="' + item.id + '" lay-filter="' + option.elem +
|
||||
'" class="layui-nav arrow layui-nav-tree pear-nav-tree">';
|
||||
|
||||
} else {
|
||||
|
||||
|
||||
controlItem = '<li pear-href="' + item.href + '" pear-title="' + item.title + '" pear-id="' + item.id +
|
||||
'" class="layui-nav-item"><a href="#">' + item.title + '</a></li>';
|
||||
|
||||
menuItem = '<ul style="display:none" pear-id="' + item.id + '" lay-filter="' + option.elem +
|
||||
'" class="layui-nav arrow layui-nav-tree pear-nav-tree">';
|
||||
|
||||
}
|
||||
|
||||
index++;
|
||||
|
||||
$.each(item.children, function(i, note) {
|
||||
|
||||
// 创 建 每 一 个 菜 单 项
|
||||
var content = '<li class="layui-nav-item" >';
|
||||
|
||||
|
||||
var href = "javascript:;";
|
||||
|
||||
|
||||
var target = "";
|
||||
|
||||
|
||||
var calss = "site-demo-active";
|
||||
|
||||
if(note.openType == "_blank" && note.type == 1){
|
||||
|
||||
|
||||
if (note.openType == "_blank" && note.type == 1) {
|
||||
|
||||
href = note.href;
|
||||
target = "target='_blank'";
|
||||
calss = "";
|
||||
}
|
||||
|
||||
|
||||
// 判 断 菜 单 类 型 0 是 不可跳转的目录 1 是 可 点 击 跳 转 的 菜 单
|
||||
|
||||
|
||||
// 判 断 菜 单 类 型 0 是 不可跳转的目录 1 是 可 点 击 跳 转 的 菜 单
|
||||
if (note.type == 0) {
|
||||
// 创 建 目 录 结 构
|
||||
content += '<a href="'+href+'" '+ target +' menu-type="'+note.type+'" menu-id="'+note.id+'" ><i class="' + note.icon + '"></i><span>' + note.title +
|
||||
content += '<a href="' + href + '" ' + target + ' menu-type="' + note.type + '" menu-id="' + note.id +
|
||||
'" ><i class="' + note.icon + '"></i><span>' + note.title +
|
||||
'</span></a>';
|
||||
} else if (note.type == 1) {
|
||||
// 创 建 菜 单 结 构
|
||||
content += '<a '+ target +' class="'+calss+'" menu-type="'+note.type+'" menu-url="' + note.href + '" menu-id="' + note.id +
|
||||
'" menu-title="' + note.title + '" href="'+href+'"><i class="' + note.icon +
|
||||
content += '<a ' + target + ' class="' + calss + '" menu-type="' + note.type + '" menu-url="' + note.href +
|
||||
'" menu-id="' + note.id +
|
||||
'" menu-title="' + note.title + '" href="' + href + '"><i class="' + note.icon +
|
||||
'"></i><span>' + note.title + '</span></a>';
|
||||
}
|
||||
// 调 用 递 归 方 法 加 载 无 限 层 级 的 子 菜 单
|
||||
content += loadchild(note);
|
||||
// 结 束 一 个 根 菜 单 项
|
||||
content += '</li>';
|
||||
|
||||
|
||||
menuItem += content;
|
||||
|
||||
|
||||
})
|
||||
|
||||
|
||||
|
||||
|
||||
menu += menuItem + '</ul>';
|
||||
|
||||
|
||||
control += controlItem;
|
||||
|
||||
})
|
||||
|
||||
|
||||
$("#"+option.control).html(control);
|
||||
|
||||
$("#"+option.elem).html(menu);
|
||||
|
||||
$("#"+option.control+" .pear-nav-control").on("click","li",function(){
|
||||
|
||||
$("#"+option.elem).find(".pear-nav-tree").css({display:'none'});
|
||||
|
||||
$("#"+option.elem).find(".pear-nav-tree[pear-id='"+$(this).attr("pear-id")+"']").css({display:'block'});
|
||||
|
||||
option.change($(this).attr("pear-id"),$(this).attr("pear-title"),$(this).attr("pear-href"))
|
||||
|
||||
})
|
||||
|
||||
|
||||
|
||||
$("#" + option.control).html(control);
|
||||
|
||||
$("#" + option.elem).html(menu);
|
||||
|
||||
$("#" + option.control + " .pear-nav-control").on("click", "li", function() {
|
||||
|
||||
$("#" + option.elem).find(".pear-nav-tree").css({
|
||||
display: 'none'
|
||||
});
|
||||
|
||||
$("#" + option.elem).find(".pear-nav-tree[pear-id='" + $(this).attr("pear-id") + "']").css({
|
||||
display: 'block'
|
||||
});
|
||||
|
||||
option.change($(this).attr("pear-id"), $(this).attr("pear-title"), $(this).attr("pear-href"))
|
||||
})
|
||||
|
||||
}
|
||||
|
||||
/** 加载子菜单 (递归)*/
|
||||
|
||||
/** 加载子菜单 (递归)*/
|
||||
function loadchild(obj) {
|
||||
|
||||
|
||||
// 判 单 是 否 是 菜 单, 如 果 是 菜 单 直 接 返 回
|
||||
if(obj.type==1){
|
||||
if (obj.type == 1) {
|
||||
return "";
|
||||
}
|
||||
|
||||
|
||||
// 创 建 子 菜 单 结 构
|
||||
var content = '<dl class="layui-nav-child">';
|
||||
|
||||
|
||||
// 如 果 嵌 套 不 等 于 空
|
||||
if (obj.children != null && obj.children.length > 0) {
|
||||
// 遍 历 子 项 目
|
||||
$.each(obj.children, function(i, note) {
|
||||
// 创 建 子 项 结 构
|
||||
content += '<dd>';
|
||||
|
||||
|
||||
var href = "javascript:;";
|
||||
|
||||
|
||||
var target = "";
|
||||
|
||||
|
||||
var calss = "site-demo-active";
|
||||
|
||||
if(note.openType == "_blank" && note.type == 1){
|
||||
|
||||
if (note.openType == "_blank" && note.type == 1) {
|
||||
href = note.href;
|
||||
target = "target='_blank'";
|
||||
calss = "";
|
||||
}
|
||||
|
||||
// 判 断 子 项 类 型
|
||||
|
||||
// 判 断 子 项 类 型
|
||||
if (note.type == 0) {
|
||||
// 创 建 目 录 结 构
|
||||
content += '<a '+ target +' href="'+href+'" menu-type="'+note.type+'" menu-id="'+note.id+'"><i class="' + note.icon + '"></i><span>' + note.title + '</span></a>';
|
||||
content += '<a ' + target + ' href="' + href + '" menu-type="' + note.type + '" menu-id="' + note.id +
|
||||
'"><i class="' + note.icon + '"></i><span>' + note.title + '</span></a>';
|
||||
} else if (note.type == 1) {
|
||||
// 创 建 菜 单 结 构
|
||||
content += '<a '+ target +' class="'+calss+'" menu-type="'+note.type+'" menu-url="' + note.href + '" menu-id="' + note.id +'" menu-title="' + note.title + '" menu-icon="' + note.icon + '" href="'+href+'" ><i class="' + note.icon +'"></i><span>' + note.title + '</span></a>';
|
||||
content += '<a ' + target + ' class="' + calss + '" menu-type="' + note.type + '" menu-url="' + note.href +
|
||||
'" menu-id="' + note.id + '" menu-title="' + note.title + '" menu-icon="' + note.icon + '" href="' + href +
|
||||
'" ><i class="' + note.icon + '"></i><span>' + note.title + '</span></a>';
|
||||
}
|
||||
// 加 载 子 项 目 录
|
||||
content += loadchild(note);
|
||||
// 结 束 当 前 子 菜 单
|
||||
content += '</dd>';
|
||||
});
|
||||
// 封 装
|
||||
|
||||
}else{
|
||||
// 封 装
|
||||
|
||||
} else {
|
||||
content += '<div class="toast"> 无 内 容 </div>';
|
||||
|
||||
/* 暂 无 数 据 */
|
||||
|
||||
/* 暂 无 数 据 */
|
||||
}
|
||||
|
||||
|
||||
content += '</dl>';
|
||||
return content;
|
||||
}
|
||||
|
||||
|
||||
|
||||
function downShow(option){
|
||||
|
||||
$("body #"+option.elem).on("click","a[menu-type='0']",function(){
|
||||
|
||||
if(!$("#"+option.elem).is(".pear-nav-mini")){
|
||||
|
||||
var superEle = $(this).parent();
|
||||
var ele = $(this).next('.layui-nav-child');
|
||||
var height = ele.height();
|
||||
if($(this).parent().is(".layui-nav-itemed")){
|
||||
|
||||
|
||||
if(option.accordion){
|
||||
// 手 风 琴 实 现
|
||||
$(this).parent().parent().find(".layui-nav-itemed").removeClass("layui-nav-itemed");
|
||||
$(this).parent().addClass("layui-nav-itemed");
|
||||
|
||||
|
||||
|
||||
|
||||
function downShow(option) {
|
||||
|
||||
$("body #" + option.elem).on("click", "a[menu-type='0']", function() {
|
||||
|
||||
if (!$("#" + option.elem).is(".pear-nav-mini")) {
|
||||
|
||||
var superEle = $(this).parent();
|
||||
var ele = $(this).next('.layui-nav-child');
|
||||
var height = ele.height();
|
||||
if ($(this).parent().is(".layui-nav-itemed")) {
|
||||
|
||||
|
||||
if (option.accordion) {
|
||||
// 手 风 琴 实 现
|
||||
$(this).parent().parent().find(".layui-nav-itemed").removeClass("layui-nav-itemed");
|
||||
$(this).parent().addClass("layui-nav-itemed");
|
||||
|
||||
}
|
||||
|
||||
ele.height(0);
|
||||
|
||||
ele.animate({
|
||||
height: height + "px"
|
||||
}, 200, function() {
|
||||
ele.css({
|
||||
height: "auto"
|
||||
});
|
||||
});
|
||||
|
||||
} else {
|
||||
|
||||
$(this).parent().addClass("layui-nav-itemed");
|
||||
|
||||
ele.animate({
|
||||
height: "0px"
|
||||
}, 200, function() {
|
||||
ele.css({
|
||||
height: "auto"
|
||||
});
|
||||
$(this).parent().removeClass("layui-nav-itemed");
|
||||
});
|
||||
|
||||
}
|
||||
|
||||
ele.height(0);
|
||||
|
||||
ele.animate({
|
||||
height: height + "px"
|
||||
},200,function() {
|
||||
ele.css({
|
||||
height: "auto"
|
||||
});
|
||||
});
|
||||
|
||||
}else{
|
||||
|
||||
$(this).parent().addClass("layui-nav-itemed");
|
||||
|
||||
ele.animate({
|
||||
height: "0px"
|
||||
},200,function() {
|
||||
ele.css({
|
||||
height: "auto"
|
||||
});
|
||||
$(this).parent().removeClass("layui-nav-itemed");
|
||||
});
|
||||
|
||||
}
|
||||
}
|
||||
})
|
||||
|
||||
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
/** 二 级 悬 浮 菜 单*/
|
||||
function isHoverMenu(b,option) {
|
||||
if (b) {
|
||||
$("#"+option.elem+".pear-nav-mini .layui-nav-item,#"+option.elem+".pear-nav-mini dd").hover(function() {
|
||||
|
||||
$(this).children(".layui-nav-child").addClass("layui-nav-hover");
|
||||
|
||||
var top = $(this).offset().top+5;
|
||||
|
||||
|
||||
if (!$(this).is(".layui-nav-item")) {
|
||||
|
||||
var left = $(this).offset().left + 132;
|
||||
|
||||
$(this).children(".layui-nav-child").offset({left:left});
|
||||
|
||||
}else{
|
||||
var left = $(this).offset().left + 62 ;
|
||||
|
||||
$(this).children(".layui-nav-child").offset({left:left});
|
||||
|
||||
}
|
||||
$(this).children(".layui-nav-child").offset({top:top});
|
||||
|
||||
|
||||
|
||||
}, function() {
|
||||
|
||||
$(this).children(".layui-nav-child").removeClass("layui-nav-hover");
|
||||
|
||||
//判断当前是dd,还是 layui-nav-item
|
||||
|
||||
$(this).children(".layui-nav-child").css({left: '0px'});
|
||||
|
||||
$(this).children(".layui-nav-child").css({top: '0px'});
|
||||
})
|
||||
} else {
|
||||
$("#"+option.elem+" .layui-nav-item").off('mouseenter').unbind('mouseleave');
|
||||
$("#"+option.elem+" dd").off('mouseenter').unbind('mouseleave');
|
||||
}
|
||||
function isHoverMenu(b, option) {
|
||||
if (b) {
|
||||
$("#" + option.elem + ".pear-nav-mini .layui-nav-item,#" + option.elem + ".pear-nav-mini dd").hover(function() {
|
||||
|
||||
$(this).children(".layui-nav-child").addClass("layui-nav-hover");
|
||||
|
||||
var top = $(this).offset().top + 5;
|
||||
|
||||
|
||||
if (!$(this).is(".layui-nav-item")) {
|
||||
|
||||
var left = $(this).offset().left + 132;
|
||||
|
||||
$(this).children(".layui-nav-child").offset({
|
||||
left: left
|
||||
});
|
||||
|
||||
} else {
|
||||
var left = $(this).offset().left + 62;
|
||||
|
||||
$(this).children(".layui-nav-child").offset({
|
||||
left: left
|
||||
});
|
||||
|
||||
}
|
||||
$(this).children(".layui-nav-child").offset({
|
||||
top: top
|
||||
});
|
||||
|
||||
|
||||
|
||||
}, function() {
|
||||
|
||||
$(this).children(".layui-nav-child").removeClass("layui-nav-hover");
|
||||
|
||||
//判断当前是dd,还是 layui-nav-item
|
||||
|
||||
$(this).children(".layui-nav-child").css({
|
||||
left: '0px'
|
||||
});
|
||||
|
||||
$(this).children(".layui-nav-child").css({
|
||||
top: '0px'
|
||||
});
|
||||
})
|
||||
} else {
|
||||
$("#" + option.elem + " .layui-nav-item").off('mouseenter').unbind('mouseleave');
|
||||
$("#" + option.elem + " dd").off('mouseenter').unbind('mouseleave');
|
||||
}
|
||||
|
||||
exports(MOD_NAME,new pearMenu());
|
||||
})
|
||||
}
|
||||
|
||||
exports(MOD_NAME, new pearMenu());
|
||||
})
|
||||
|
|
|
|||
|
|
@ -71,18 +71,11 @@
|
|||
|
||||
var config = {
|
||||
keepLoad: 1200, // 主 页 加 载 过 度 时 长 可为 false
|
||||
muiltTab: true, // 是 否 开 启 多 标 签 页 true 开启 false 关闭
|
||||
muiltTab: false, // 是 否 开 启 多 标 签 页 true 开启 false 关闭
|
||||
control: false, // 是 否 开 启 多 系 统 菜 单 true 开启 false 关闭
|
||||
theme: "dark-theme", // 默 认 主 题 样 式 dark-theme 默认主题 light-theme 亮主题
|
||||
index: 'view/console/console1.html', // 默 认 加 载 主 页
|
||||
data: 'admin/data/menu.json', // 菜 单 数 据 加 载 地 址
|
||||
change: function(id,title,href){
|
||||
|
||||
// 顶部菜单切换事件
|
||||
},
|
||||
done: function() {
|
||||
/** 框架初始化 */
|
||||
}
|
||||
};
|
||||
|
||||
pearAdmin.render(config);
|
||||
|
|
|
|||
Loading…
Reference in New Issue