右侧菜单
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>部门管理--右侧列表</title> <meta name="renderer" content="webkit"> <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"> <meta http-equiv="Access-Control-Allow-Origin" content="*"> <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"> <meta name="apple-mobile-web-app-status-bar-style" content="black"> <meta name="apple-mobile-web-app-capable" content="yes"> <meta name="format-detection" content="telephone=no"> <link rel="icon" href="/favicon.ico"> <link rel="stylesheet" href="/resources/layui/css/layui.css" media="all" /> <link rel="stylesheet" href="/resources/css/public.css" media="all" /> </head> <body class="childrenBody"> <!-- 查询条件开始 --> <fieldset class="layui-elem-field layui-field-title" style="margin-top: 5px;"> <legend>查询条件</legend> </fieldset> <blockquote class="layui-elem-quote"> <form action="" method="post" id="searchFrm" lay-filter="searchFrm" class="layui-form layui-form-pane"> <div class="layui-form-item"> <div class="layui-inline"> <label class="layui-form-label">部门名称</label> <div class="layui-input-inline"> <input type="text" name="title" autocomplete="off" class="layui-input"> </div> </div> <div class="layui-inline"> <label class="layui-form-label">部门备注</label> <div class="layui-input-inline"> <input type="text" name="remark" autocomplete="off" class="layui-input"> </div> </div> <div class="layui-inline"> <label class="layui-form-label">部门地址</label> <div class="layui-input-inline"> <input type="text" name="address" autocomplete="off" class="layui-input"> </div> </div> </div> <div class="layui-form-item"> <div class="layui-input-block" style="text-align: center;"> <button type="button" class="layui-btn" lay-submit="" lay-filter="doSearch"><span class="layui-icon layui-icon-search"></span>查询</button> <button type="reset" class="layui-btn layui-btn-warm"><span class="layui-icon layui-icon-refresh-1"></span>重置</button> </div> </div> </form> </blockquote> <!-- 查询条件结束--> <!-- 数据表格开始 --> <div> <table class="layui-hide" id="deptTable" lay-filter="deptTable"></table> <div id="deptToolBar" style="display: none;"> <button type="button" lay-event="add" class="layui-btn layui-btn-sm"><span class="layui-icon layui-icon-add-1"></span>添加部门</button> </div> <div id="deptRowBar" style="display: none;"> <button type="button" lay-event="update" class="layui-btn layui-btn-sm"><span class="layui-icon layui-icon-edit"></span>修改</button> <button type="button" lay-event="delete" class="layui-btn layui-btn-sm layui-btn-danger"><span class="layui-icon layui-icon-delete"></span>删除</button> </div> </div> <!-- 数据表格结束 --> <!-- 添加和修改的弹出层开始 --> <div style="display: none;padding: 5px" id="addOrUpdateDiv"> <form action="" method="post" class="layui-form " id="dataFrm" lay-filter="dataFrm"> <div class="layui-form-item"> <label class="layui-form-label">部门标题</label> <div class="layui-input-block"> <!--隐藏域id--> <input type="hidden" name="id"> <input type="text" name="title" lay-verify="required" autocomplete="off" placeholder="请输入标题" class="layui-input"> </div> </div> <div class="layui-form-item"> <label class="layui-form-label">备注</label> <div class="layui-input-block"> <input type="text" name="remark" lay-verify="required" autocomplete="off" placeholder="请输入备注" class="layui-input"> </div> </div> <div class="layui-form-item"> <label class="layui-form-label">地址</label> <div class="layui-input-block"> <input type="text" name="address" lay-verify="required" autocomplete="off" placeholder="请输入备注" class="layui-input"> </div> </div> <div class="layui-form-item"> <div class="layui-input-block" style="text-align: center;"> <button type="button" class="layui-btn" lay-submit="" id="doSubmit" ><span class="layui-icon layui-icon-release"></span>提交</button> <button type="reset" class="layui-btn layui-btn-warm"><span class="layui-icon layui-icon-refresh-1"></span>重置</button> </div> </div> </form> </div> <!-- 添加和修改的弹出层结束 --> <script type="text/javascript" src="/resources/layui/layui.js"></script> <script type="text/javascript"> var tableIns;//提高作用域 layui.use([‘jquery‘,‘form‘,‘table‘,‘layer‘],function(){ var $=layui.jquery; var form=layui.form; var table=layui.table; var layer=layui.layer; //加载 数据 tableIns=table.render({ elem: ‘#deptTable‘ ,url:‘/dept/loadAllDept‘ ,toolbar: ‘#deptToolBar‘ //开启头部工具栏,并为其绑定左侧模板 ,title: ‘部门数据表‘ ,height:‘full-220‘ ,page: true ,cols: [ [ {field:‘id‘, title:‘ID‘,align:‘center‘,width:‘70‘} ,{field:‘pid‘, title:‘父级部门ID‘,align:‘center‘,width:‘100‘} ,{field:‘title‘, title:‘部门名称‘,align:‘center‘,width:‘100‘} ,{field:‘remark‘, title:‘部门备注‘,align:‘center‘,width:‘100‘} ,{field:‘open‘, title:‘是否展开‘,align:‘center‘,width:‘100‘, templet:function (d) { return d.open==1?‘<font color=blue>展开</font>‘:‘<font color=red>不展开</font>‘; }} ,{field:‘available‘, title:‘是否可用‘,align:‘center‘,width:‘100‘, templet:function (d) { return d.available==1?‘<font color=blue>可用</font>‘:‘<font color=red>不可用</font>‘; }} ,{field:‘address‘, title:‘部门地址‘,align:‘center‘,width:‘100‘} ,{field:‘ordernum‘, title:‘排序码‘,align:‘center‘,width:‘100‘} ,{field:‘createtime‘, title:‘创建时间‘,align:‘center‘,width:‘200‘} ,{fixed: ‘right‘, title:‘操作‘, toolbar: ‘#deptRowBar‘,align:‘center‘,width:‘200‘} ] ] }); //模糊查询 form.on("submit(doSearch)",function(data){ tableIns.reload({ where:data.field, page:{ curr:1 } }); return false; }); //监听工具条的事件 table.on("toolbar(deptTable)",function(obj){ switch(obj.event){ case ‘batchDelete‘: batchDelete(); break; case ‘add‘: openAddLayer(); break; }; }); //监听行工具条的事件 table.on("tool(deptTable)",function(obj){ var data = obj.data; //获得当前行数据 switch(obj.event){ case ‘update‘: openUpdateDeptLayer(data); break; case ‘delete‘: deleteDept(data); break; case ‘show‘: showDept(data); break; }; }); var mainIndex; var url; //打开添加的弹出层 function openAddLayer(){ mainIndex=layer.open({ type:1, content:$("#addOrUpdateDiv"), area:[‘800px‘,‘480px‘], title:‘发布部门‘, success:function(){ $("#dataFrm")[0].reset(); layedit.setContent(editIndex,""); url="/dept/addDept"; } }); } //打开修改的弹出层 function openUpdateDeptLayer(data){ mainIndex=layer.open({ type:1, content:$("#addOrUpdateDiv"), area:[‘800px‘,‘480px‘], title:‘修改部门‘, success:function(){ $("#dataFrm")[0].reset(); //装载新的数据 form.val("dataFrm",data); layedit.setContent(editIndex,data.content); url="/dept/updateDept"; } }); } $("#doSubmit").click(function(){ //同步富文本和textarea里面的内容 layedit.sync(editIndex); var data=$("#dataFrm").serialize(); $.post(url,data,function(res){ if(res.code==200){ tableIns.reload(); } layer.msg(res.msg); layer.close(mainIndex); }) }) //删除 function deleteDept(data){ layer.confirm(‘你确定要删除【‘+data.title+‘】这条部门吗?‘, {icon: 3, title:‘提示‘}, function(index){ $.post("/dept/deleteDept",{id:data.id},function(res){ if(res.code==200){ tableIns.reload(); } layer.msg(res.msg); }) layer.close(index); }); } //批量删除 function batchDelete(){ //得到选中行 var checkStatus = table.checkStatus(‘deptTable‘); var dataLength=checkStatus.data.length; if(dataLength>0){ layer.confirm(‘你确定要删除这些部门数据吗?‘, {icon: 3, title:‘提示‘}, function(index){ var data=checkStatus.data; //获取选中行的数据 var ids=""; $.each(data,function(index,item){ if(index==0){ ids+="ids="+item.id; }else{ ids+="&ids="+item.id; } }) $.post("/dept/batchDeleteDept",ids,function(res){ if(res.code==200){ tableIns.reload(); } layer.msg(res.msg); }) layer.close(index); }); }else{ layer.msg("请选中操作行") } } //弹出查看层 function showDept(data){ mainIndex=layer.open({ type:1, content:$("#showDeptDiv"), area:[‘800px‘,‘480px‘], title:‘查看部门‘, success:function(){ $("#show_title").html(data.title); $("#show_opername").html(data.opername); $("#show_createtime").html(data.createtime); $("#show_content").html(data.content); } }); } }); //外部定义方法 //给其他页面刷新当前页面的方法 function reloadTable(id) { tableIns.reload({ where:{ id:id } }); } </script> </body> </html>
左侧部门树
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>左侧部门树</title>
<meta name="renderer" content="webkit">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<meta http-equiv="Access-Control-Allow-Origin" content="*">
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
<meta name="apple-mobile-web-app-status-bar-style" content="black">
<meta name="apple-mobile-web-app-capable" content="yes">
<meta name="format-detection" content="telephone=no">
<link rel="icon" href="/favicon.ico">
<link rel="stylesheet" href="/resources/layui/css/layui.css" media="all" />
<link rel="stylesheet" href="/resources/css/public.css" media="all" />
<link rel="stylesheet" href="/resources/layui_ext/dtree/dtree.css" media="all" />
<link rel="stylesheet" href="/resources/layui_ext/dtree/font/dtreefont.css" media="all" />
</head>
<body>
<!-- 存放树的容器 -->
<ul id="deptTree" class="dtree" data-id="0"></ul>
<script type="text/javascript" src="/resources/layui/layui.js"></script>
<script type="text/javascript">
layui.extend({
dtree: ‘/resources/layui_ext/dtree/dtree‘ // {/}的意思即代表采用自有路径,即不跟随 base 路径
}).use([‘dtree‘,‘layer‘,‘jquery‘], function(){
var dtree = layui.dtree;
var layer = layui.layer;
$ = layui.jquery;
// 初始化树
var deptTree = dtree.render({
elem: "#deptTree",
dataStyle:"layuiStyle", //使用layui 数据风格的格式
dataFormat: "list", //配置data风格为list
response:{message:"msg",statusCode:0}, //修改response中返回数据的定义
url: "/dept/loadDeptManageLeftTreeJson" // 使用url加载(可与data加载同时存在)
});
// 绑定节点点击
dtree.on("node(deptTree)" ,function(obj){
//layer.msg(JSON.stringify(obj.param));
//刷新其他页面的信息
window.parent.right.reloadTable(obj.param.nodeId);
});
});
</script>
</body>
</html>
将两个部分连接起来的桥梁 ---父类部分
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>部门管理</title>
</head>
<frameset cols="200,*" border="1" frameborder="yes">
<frame src="/sys/toDeptLeft" name="left">
<frame src="/sys/toDeptRight" name="right">
</frameset>
</html>
/**
* 查询
*/
@RequestMapping("loadAllDept")
public DataGridView loadAllDept(DeptVo deptVo) {
IPage<Dept> page=new Page<>(deptVo.getPage(), deptVo.getLimit());
QueryWrapper<Dept> queryWrapper=new QueryWrapper<>();
queryWrapper.like(StringUtils.isNotBlank(deptVo.getTitle()), "title", deptVo.getTitle());
queryWrapper.like(StringUtils.isNotBlank(deptVo.getAddress()), "address", deptVo.getAddress());
queryWrapper.like(StringUtils.isNotBlank(deptVo.getRemark()), "remark", deptVo.getRemark());
//判断条件
queryWrapper.eq(deptVo.getId()!=null, "id", deptVo.getId()).or().eq(deptVo.getId()!=null,"pid", deptVo.getId());
//排序
queryWrapper.orderByAsc("ordernum");
this.deptService.page(page, queryWrapper);
return new DataGridView(page.getTotal(), page.getRecords());
}
原文:https://www.cnblogs.com/zhsv/p/12515084.html