最近有个项目使用Layui框架进行后端系统的界面搭建,其中Layui框架中的Layer组件在项目中会用得非常多。且有些功能会遇到子窗口完成数据的提交后,进行关闭同时会刷新父窗口的数据,所以此文章分享一下《如何实现在Layui框架中完成父窗的刷新功能》
当然这里有朋友就会吐槽,现在的项目都是基于SpringBoot + Vue的前后端分离开发。在这里我要说明一下此文章是分享给目前学习 或 正在使用Layui框架的朋友们
先看一个动态的gif效果图
主要技术栈:SpringBoot + Redis + Layui + MySQL
这里就根据动态的gif效果图,来说明一下前端效果的实现
前端流程:
- 通过Layui的Table组件展示数据
- 点击“编辑”按钮,进入编辑页面(第一级子窗口)
- 再次选择要变更“上级部门”按钮,进入选择“上级部门”的子窗口(第二级子窗口)
- 确认所有的编辑数据,然后进行保存
- 如果保存成功,则刷性父窗口
编辑页面 - 子窗口 - 前端代码
<html lang="en" xmlns:th="http://www.thymeleaf.org"> | |
<head><meta charset="UTF-8"><title>部门管理 - 新增</title><meta name="renderer" content="webkit"><meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"><meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"><link rel="stylesheet" href="/lib/layui-v2.5.5/css/layui.css" media="all"><link rel="stylesheet" href="/css/public.css" media="all"><style>body { | |
background-color: #ffffff; | |
} | |
</style> | |
</head> | |
<body> | |
<div class="layui-form layuimini-form"><div class="layui-form-item"><label class="layui-form-label required">部门名称</label><div class="layui-input-block"><input type="hidden" name="section_id" th:value="${section_id}" id="section_id"><input type="text" name="section_name" lay-verify="required" lay-reqtext="用户名不能为空" placeholder="请输入用户名" class="layui-input" id="section_name" th:value="${section_name}"><tip>填写管理部门的名称</tip></div></div> | |
<div class="layui-form-item"><label class="layui-form-label required">上级部门</label><div class="layui-input-block"><input type="hidden" name="section_pId" th:value="${section_pId}" id="section_pId"><span>目前所属部门:<span th:text="${section_pName}" id="section_pName"></span></span><!--<select name="section_pId" lay-verify="required" id="section_pId"></select>--><button type="button" class="layui-btn" id="editButton">选择变更部门</button><tip>填写上级部门的名称</tip></div></div> | |
<div class="layui-form-item"><div class="layui-input-block"><button class="layui-btn" lay-submit lay-filter="saveBtn">确认保存</button></div></div> | |
</div> | |
</body> | |
<script src="/lib/jquery-3.4.1/jquery-3.4.1.min.js" charset="utf-8"></script> | |
<script src="/lib/layui-v2.5.5/layui.js" charset="utf-8"></script> | |
<script> | |
layui.use(['form', 'layer'], function() { | |
var form = layui.form; | |
var layer = layui.layer; | |
var $ = layui.jquery; | |
var section_id = $("#section_id").val(); | |
// layui.form.render("select"); | |
$("#editButton").on('click', function () { | |
layer.open({ | |
title: '变更上级部门', | |
type: 2, | |
shade: 0.2, | |
maxmin:true, | |
shadeClose: true, | |
area: ['70%', '70%'], | |
content: '/section/edit_layer', | |
success: function(layero, index) { // 回调函数用于父窗口传递数据到子窗口var body = layer.getChildFrame('body', index); // 少了这个是不能从父页面向子页面传值的 | |
body.contents().find("#section_id").val(section_id); | |
} | |
}) | |
}); | |
form.on('submit(saveBtn)', function(data) { | |
$.ajax({ | |
url: 'updateDsSection', | |
method: 'post', | |
dataType: 'json', | |
data: data.field, | |
success: function(e) { | |
if(e.code > 0) { | |
window.parent.layer.msg('数据编辑成功'); | |
} else { | |
window.parent.layer.msg('数据编辑失败'); | |
} | |
}, | |
error: function() { | |
window.parent.layer.msg('服务器有异常'); | |
} | |
}); | |
// 关闭窗口// parent - BOM对象 - 子父级窗口对象之间联系var iframeIndex = parent.layer.getFrameIndex(window.name); | |
parent.layer.close(iframeIndex); | |
return false; | |
}); | |
}); | |
</script> | |
</html> |
选择即将变更“上级部门” - 弹出子窗口 - 前端代码
<html lang="en" xmlns:th="http://www.thymeleaf.org"> | |
<head><meta charset="UTF-8"><title>部门管理 - 更新变更</title><meta name="renderer" content="webkit"><meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"><meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"><link rel="stylesheet" href="../lib/layui-v2.5.5/css/layui.css" media="all"><link rel="stylesheet" href="../css/public.css" media="all"> | |
</head> | |
<body> | |
<div class="layuimini-container"><div class="layuimini-main"><input type="hidden" value="" id="section_id"> | |
<table class="layui-hide" id="currentTableId" lay-filter="currentTableFilter"></table> | |
<script type="text/html" id="currentTableBar"><a class="layui-btn layui-btn-xs data-count-edit" lay-event="edit">变更部门</a></script></div> | |
</div> | |
</body> | |
<script src="../lib/layui-v2.5.5/layui.js" charset="utf-8"></script> | |
<script th:inline="none"> | |
layui.use(['table', 'layer'], function() { | |
var $ = layui.jquery, table = layui.table; | |
var section_id = $("#section_id").val(); | |
var tableIns = table.render({ | |
elem: '#currentTableId', | |
url: 'getDsSectionListByIdToEdit?section_id='+section_id, | |
cellMinWidth:80, // 全局定义常规单元格的最小宽度, layui2.2.1 新增cols: [[ | |
{field: 'id', title: '部门编号', sort: true}, | |
{field: 'name', title: '部门名称', sort: true}, | |
{title: '操作', minWidth: 50, templet: '#currentTableBar', fixed: "right", align: "center"} | |
]], | |
}); | |
table.on('tool(currentTableFilter)', function(obj) { | |
var data = obj.data; | |
if(obj.event == 'edit') { | |
layer.confirm('确定变更上级部门吗?', function (index) { | |
parent.document.querySelector("#section_pName").innerHTML = data.name; // 设置父级窗口的值 | |
parent.document.querySelector("#section_pId").value = data.id; | |
layer.close(index); // 关闭确认对话框var iframeIndex = parent.layer.getFrameIndex(window.name); // 关闭父级窗口 | |
parent.layer.close(iframeIndex); | |
}); | |
} | |
}); | |
}) | |
</script> | |
</html> |
父窗窗口 - 刷新 - 核心代码
table.on('tool(currentTableFilter)', function (obj) { | |
var data = obj.data; | |
if (obj.event === 'edit') { | |
var index = layer.open({ | |
title: '编辑用户', | |
type: 2, | |
shade: 0.2, | |
maxmin:true, | |
shadeClose: true, | |
area: ['100%', '100%'], | |
content: '/section/edit?section_id='+data.section_id+"§ion_name="+data.section_name+"§ion_pId="+data.section_pId+"§ion_pName="+data.section_pName, | |
success: function(layero, index) { // 回调函数用于父窗口传递数据到子窗口// 代码根据实际情况进行编写 | |
}, | |
end: function() { | |
// 刷新父窗口 - 刷新Table - 时间延迟 等待弹出层消失后setTimeout(function(){ | |
window.location.reload(); | |
}, 2000); | |
} | |
}); | |
$(window).on("resize", function () { | |
layer.full(index); | |
}); | |
return false; | |
} else if (obj.event === 'delete') { | |
layer.confirm('真的删除行么', function (index) { | |
$.ajax({ | |
url: 'deleteDsSectionById', | |
type: 'GET', | |
data: {'section_id': data.section_id}, | |
dataType: 'json', | |
success: function(res) { | |
if(res.code > 0) { | |
layer.msg('删除成功...') | |
obj.del(); | |
setTimeout(function() { | |
location.reload(); | |
}, 2000); | |
} else { | |
layer.msg('删除失败...') | |
} | |
} | |
}); | |
layer.close(index); | |
}); | |
} | |
}); |
注意,如果实现关闭子窗口,父窗口进行刷新,一定要在 "layer.open" 加入 "end:function() {}" 回调函数
如果还有朋友们对上面代码不是清楚的,可以在下方留言