OA项目之左侧菜单&动态选项卡(三)

简介: OA项目之左侧菜单&动态选项卡

二.动态选项卡&左侧菜单

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE>
<html>
<head>
  <%@include file="/common/head.jsp" %>
</head>
<style>
  .layui-tab-title>li:first-child>i{
    display:none;
  }
  .layui-tab>.layui-tab-content{
    padding:0px;
  }
  body,html{
    padding:0px;
    margin:0px;
    overflow:hidden;
  }
  .layui-body{
      background: url(images/壁纸03.jpg) ;
    }
</style>
<body>
<div class="layui-layout layui-layout-admin">
  <div class="layui-header ">
    <div class="layui-logo layui-hide-xs layui-bg-black">会议OA管理系统</div>
    <!-- 头部区域(可配合layui 已有的水平导航) -->
    <ul class="layui-nav layui-layout-left">
      <!-- 移动端显示 -->
      <li class="layui-nav-item layui-show-xs-inline-block layui-hide-sm" lay-header-event="menuLeft">
        <i class="layui-icon layui-icon-spread-left"></i>
      </li>
    </ul>
    <!-- 个人头像及账号操作 -->
    <ul class="layui-nav layui-layout-right">
      <li class="layui-nav-item layui-hide layui-show-md-inline-block">
        <a href="javascript:;">
          <img src="${ctx }/images/壁纸3.png" class="layui-nav-img">
          ${sessionScope.user.name }
        </a>
        <dl class="layui-nav-child">
          <dd><a href="#">个人中心</a></dd>
          <dd><a href="#">系统设置</a></dd>
          <dd><a href="#" id="logout">安全退出</a></dd>
        </dl>
      </li>
      <li class="layui-nav-item" lay-header-event="menuRight" lay-unselect>
        <a href="javascript:;">
          <i class="layui-icon layui-icon-more-vertical"></i>
        </a>
      </li>
    </ul>
  </div>
  <div class="layui-side layui-bg-black">
    <div class="layui-side-scroll">
      <!-- 左侧导航区域(可配合layui已有的垂直导航) -->
      <ul id="menu" class="layui-nav layui-nav-tree">
      </ul>
    </div>
  </div>
  <div class="layui-body">
    <div class="layui-tab" lay-filter="tabs" lay-allowClose="true" style="margin:0px;">
    <ul class="layui-tab-title">
      <li class="layui-this">首页</li>
    </ul>
    <div class="layui-tab-content">
      <div class="layui-tab-item layui-show">
        <!-- <i class="bi bi-balloon-heart">欢迎来到瑶大头工作室</i> -->
        <!-- <img alt="" src="/images/壁纸3.png"> -->
      </div>
    </div>
  </div>
  </div>
  <div class="layui-footer" style="text-align:center;">
    <!-- 底部固定区域 -->
           Copyright @ 2008-2022 www.zking.com
  </div>
</div>
<script>
//JS 
var element, $, layer, util;
layui.use(['element', 'layer', 'util', 'jquery'], function(){
   element = layui.element
  ,layer = layui.layer
  ,util = layui.util
  ,$ = layui.$;
  //头部事件
  util.event('lay-header-event', {
    //左侧菜单事件
    menuLeft: function(othis){
      layer.msg('展开左侧菜单的操作', {icon: 0});
    }
    ,menuRight: function(){
      layer.open({
        type: 1
        ,content: '<div style="padding: 15px;">处理右侧面板的操作</div>'
        ,area: ['260px', '100%']
        ,offset: 'rt' //右上角
        ,anim: 5
        ,shadeClose: true
      });
    }
  });
  //动态生成菜单
  $.ajax({
    url: ctx+"/permissionAction.action?methodName=listPermission",
    type: "get",
    dataType: 'json',
    success:function(resp) {
      //循环生成菜单
      $.each(resp.data, function(index, val) {
        //默认打开第一个菜单,layui-nav-itemed样式为打开菜单样式
        let selected = index == 0 ? 'layui-nav-itemed' : '';
        let li = $('<li class="layui-nav-item ' + selected + '"></li>');
        //一级菜单
        li.append('<a class="" href="javascript:;"><i class="layui-icon '
            + val.icon
            + '" style="font-size:16px;margin-right:10px;"></i>' 
            + val.name + '</a>');
        //如果有子菜单,则生成子菜单
        let chidren=val.children;
        let dl = $('<dl class="layui-nav-child"></dl>');
        $.each(chidren, function(i, n) {
          //dl.append('<dd style="margin-left:40px;">'+n.name+'</dd>');
          //添加菜单点击事件
          dl.append('<dd style="margin-left:40px;"><a href="javascript:openFuncTab(\''+n.name+'\', \''+n.url+'\', \''+n.id+'\');">'+n.name+'</a></dd>');
        });
        li.append(dl);
        //将生成的菜单挂载到menu容器
        $("#menu").append(li);
      });
      //动态的生成菜单后,调用render方法进行重新渲染,可以使用init()方法进行初始化达到同样的效果
      element.render('menu');
    }
  });
  //安全退出
  $("#logout").click(function() {
    layer.confirm('亲,你舍得走吗?', {icon: 3, title:'提示'}, function(index) {
      $.ajax({
       url: ctx+"/userAction.action?methodName=logout",
       type: 'get',
       dataType: "json",
       success: function(resp) {
         if(resp.code == 1) {
           layer.msg("安全退出");
           location.href="login.jsp";
         }
       }
      });
    });
  });
});
//动态打开TAB页
function openFuncTab(name, url,id) {
    let exit = $("li[lay-id='"+id+"']").length;
    debugger;
    //如果不存在对应的TAB则动态生成
    if(exit == 0) {
      //注意此处的tabs,要与TAB页容器的lay-filter="tabs"报错保持一致
      element.tabAdd('tabs', {
        title: name,
        //在TAB页中打开指定的页面
        content: '<iframe id="myiframe" frameborder="0" src="' + url+ '" scrolling="auto" style="width:100%;height:100%;"></iframe>',
        id: id
      });
    }
    //将点击的功能设置为当前TAB
    element.tabChange('tabs', id);
    setIframHeight();
    //添加页面尺寸变化的监听事件
    $(window).resize(function() {
      setIframHeight();
    })
}
//解决页面的自适应高度问题
function setIframHeight() {
    let h = $('.layui-body').height() - 40;
    $('#myiframe').css("height", h+"px");
}
</script>
</body>
</html>

三.效果展示

左侧菜单

动态选项卡

会议发布界面

相关文章
|
11月前
|
存储 JavaScript 前端开发
会议OA项目之会议发布(详解)
会议OA项目之会议发布(详解)
79 0
|
10月前
|
BI 数据安全/隐私保护 UED
以产品经理的角度去讲解原型图---会议OA项目
以产品经理的角度去讲解原型图---会议OA项目
|
10月前
|
开发框架 JavaScript 前端开发
J2EE项目部署与发布(Windows版本)->会议OA单体项目Windows部署,spa前后端分离项目Windows部署
J2EE项目部署与发布(Windows版本)->会议OA单体项目Windows部署,spa前后端分离项目Windows部署
60 0
|
10月前
会议OA项目-其它页面->自定义组件应用,其它界面的布局
会议OA项目-其它页面->自定义组件应用,其它界面的布局
37 0
|
10月前
|
容器
会议OA项目-首页->flex弹性布局,轮播图后台数据获取及组件使用(后台数据交互mockjs),首页布局
会议OA项目-首页->flex弹性布局,轮播图后台数据获取及组件使用(后台数据交互mockjs),首页布局
70 0
|
10月前
|
JavaScript 应用服务中间件 Linux
【Linux】部署单机OA项目及搭建spa前后端分离项目
【Linux】部署单机OA项目及搭建spa前后端分离项目
63 0
|
10月前
|
JSON 小程序 前端开发
微信小程序----会议oa项目---首页
微信小程序----会议oa项目---首页
53 0
|
10月前
|
JavaScript Java
layui会议OA项目数据表格新增改查
layui会议OA项目数据表格新增改查
50 0
|
11月前
|
JSON 小程序 JavaScript
微信小程序开发之自定义组件(会议OA项目其他页面搭建)
微信小程序开发之自定义组件(会议OA项目其他页面搭建)
95 0
|
11月前
|
小程序 JavaScript UED
微信小程序开发之会议OA项目首页搭建
微信小程序开发之会议OA项目首页搭建
133 0