layui.define(['table', 'jquery', 'element'], function(exports) { "use strict"; var MOD_NAME = 'menu', $ = layui.jquery, element = layui.element; 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, defaultSelect: opt.defaultSelect, 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() {} } // 根 据 请 求 方 式 获 取 数 据 if (option.async) { option.data = getData(option.url); if (option.parseData != false) { option.parseData(option.data); } } if (option.data.length > 0) { if (option.control != false) { createMenuAndControl(option); } 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"), menuPath: dom.attr("menu-title"), menuIcon: dom.attr("menu-icon"), menuUrl: dom.attr("menu-url") }; var doms = hash(dom); if (doms.text() != '') { data['menuPath'] = doms.find("span").text() + " / " + data['menuPath']; } var domss = hash(doms); if (domss.text() != '') { data['menuPath'] = domss.find("span").text() + " / " + data['menuPath']; } var domsss = hash(domss); if (domsss.text() != '') { data['menuPath'] = domsss.find("span").text() + " / " + data['menuPath']; } 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"); } // 根 据 菜 单 Id 选 中 菜 单 项 目 if (this.option.accordion == true) { $("#" + 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"); } $("#" + this.option.elem + " a[menu-id='" + pearId + "']").parent().addClass("layui-this"); } var activeMenus; 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"); }) $("#" + 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) { $.ajaxSettings.async = false; var data = null; $.get(url, function(result) { data = result; }); $.ajaxSettings.async = true; return data; } function createMenu(option) { // 声 明 头 部 var menuHtml = '
"; // 将 菜 单 拼 接 到 初 始 化 容 器 中 $("#" + option.elem).html(menuHtml); } function createMenuAndControl(option) { var control = '