前端弹出审批对话框未显示后端传回的json
package com.imooc.oa.controller; import com.alibaba.fastjson.JSON; import com.imooc.oa.entity.LeaveForm; import com.imooc.oa.entity.User; import com.imooc.oa.service.LeaveFormService; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import javax.servlet.http.*; import javax.servlet.annotation.*; import java.io.IOException; import java.text.SimpleDateFormat; import java.util.Date; import java.util.HashMap; import java.util.List; import java.util.Map; @WebServlet(name = "LeaveFormServlet", value = "/leave/*") public class LeaveFormServlet extends HttpServlet { private LeaveFormService leaveFormService = new LeaveFormService(); private Logger logger = LoggerFactory.getLogger(LeaveFormServlet.class); @Override protected void doGet(HttpServletRequest request, HttpServletResponse response) throws IOException { this.doPost(request, response); } @Override protected void doPost(HttpServletRequest request, HttpServletResponse response) throws IOException { request.setCharacterEncoding("utf-8"); response.setContentType("text/html;charset=utf-8"); // http://localhost/leave/create 获取"create" String uri = request.getRequestURI(); System.out.println(uri); String methodName = uri.substring(uri.lastIndexOf("/")+1); if (methodName.equals("create")){ this.create(request,response); }else if(methodName.equals("list")){ this.getLeaveFormList(request, response); } } private void create(HttpServletRequest request, HttpServletResponse response) throws IOException{ HttpSession session = request.getSession(); User user = (User)session.getAttribute("login_user"); String formType = request.getParameter("formType"); String strStartTime = request.getParameter("startTime"); String strEndTime = request.getParameter("endTime"); String reason = request.getParameter("reason"); SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd-HH"); Map<String,String> result = new HashMap<> (); try { LeaveForm leaveForm = new LeaveForm(); leaveForm.setEmployeeId(user.getEmployeeId()); leaveForm.setStartTime(sdf.parse(strStartTime)); leaveForm.setEndTime(sdf.parse(strEndTime)); leaveForm.setFormType(Integer.parseInt(formType)); leaveForm.setReason(reason); leaveForm.setCreateTime(new Date()); leaveFormService.createLeaveForm(leaveForm); result.put("code", "0"); result.put("message", "success"); } catch (Exception e) { logger.error("errorMessage",e); result.put("code", e.getClass().getSimpleName()); result.put("message", e.getMessage()); } String json = JSON.toJSONString(result); response.getWriter().println(json); } public void getLeaveFormList(HttpServletRequest request,HttpServletResponse response) throws IOException { User user = (User)request.getSession().getAttribute("login_user"); List<Map> formList = leaveFormService.getLeaveFormList("process", user.getEmployeeId()); Map result = new HashMap(); result.put("code", 0); result.put("msg", ""); result.put("count", formList.size()); result.put("data",formList); String json = JSON.toJSONString(result); response.getWriter().println(json); } }
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>请假审批</title> <link rel="stylesheet" href="/resources/layui/css/layui.css"> <style> .form-item{ padding: 10px; } .form-item-value{ padding: 10px; } </style> </head> <body> <div class="layui-row"> <blockquote class="layui-elem-quote"> <h1>请假审批</h1> </blockquote> <!--待审批列表--> <table id="grdFormList" lay-filter="grdFormList"></table> </div> <!--请假详情对话框--> <div id="divDialog" style="display: none;padding: 10px"> <form class="layui-form"> <div class="layui-form-item"> <div class="layui-row"> <div class="layui-col-xs2 form-item">部门</div> <div class="layui-col-xs4 form-item-value" id="dname"></div> <div class="layui-col-xs2 form-item">姓名</div> <div class="layui-col-xs4 form-item-value" id="name"></div> </div> <div class="layui-row"> <div class="layui-col-xs2 form-item">起始时间</div> <div class="layui-col-xs4 form-item-value" id="startTime"></div> <div class="layui-col-xs2 form-item">结束时间</div> <div class="layui-col-xs4 form-item-value" id="endTime"></div> </div> <div class="layui-row"> <div class="layui-col-xs2 form-item">请假原因</div> <div class="layui-col-xs10 form-item-value" id="reason"></div> </div> <!--表单Id--> <input type="hidden" name="formId" id="formId"> <!--审批结果--> <select name="result" lay-verfity="required"> <option value="approved">同意</option> <option value="refused">驳回</option> </select> </div> <div class="layui-form-item"> <!--审批意见--> <input type="text" name="reason" placeholder="请输入审批意见" autocomplete="off" class="layui-input"/> </div> <div class="layui-form-item"> <button class="layui-btn layui-btn-fluid " lay-submit lay-filter="audit">确认提交</button> </div> </form> </div> <script src="/resources/layui/layui.all.js"></script> <script src="/resources/sweetalert2.all.min.js"></script> <script> var $ = layui.$; //将毫秒数转换为"yyyy-MM-dd HH时"字符串格式 function formatDate(time){ var newDate = new Date(time); return newDate.getFullYear() + "-" + (newDate.getMonth() + 1) + "-" + newDate.getDate() + " " + newDate.getHours() + "时"; } // 将table渲染为数据表格 layui.table.render({ elem : "#grdFormList" , //选择器 id : "grdFormList" , //id url : "/leave/list" , //ajax请求url page : false , //是否分页 true-是 false-否 cols :[[ //列描述 {title : "" , width:70 , style : "height:60px" , type:"numbers"}, // numbers代表序号列 {field : "create_time" , title : "申请时间" , width : 150 , templet: function (d) { //templet代表对数据进行加工后再显示 return formatDate(d.create_time) }}, {field : "form_type" , title : "类型" , width : 100 , templet: function(d){ switch (d.form_type) { case 1: return "事假"; case 2: return "病假"; case 3: return "工伤假"; case 4: return "婚假"; case 5: return "产假"; case 6: return "丧假"; } }}, {field : "department_name" , title : "部门" , width : 100}, {field : "name" , title : "员工" , width : 100}, {field : "start_time" , title : "起始时间" , width : 150, templet: function (d) { return formatDate(d.start_time) }}, {field : "end_time" , title : "结束时间" , width : 150 , templet: function (d) { return formatDate(d.end_time) }}, {field : "reason" , title : "请假原因" , width : 350 }, {title : "" , width:150 ,type:"space" , templet : function(d){ var strRec = JSON.stringify(d); console.info("请假单数据", strRec); //将请假单数据存放至data-laf属性中 return "<button class='layui-btn layui-btn-danger layui-btn-sm btn-audit' data-laf=" + strRec + " >审批</button>"; }} ]] }) // 绑定每一行的审批按钮 $(document).on("click" , ".btn-audit" , function(){ //初始化表单 $("#divDialog form")[0].reset(); $("#divDialog form form-item-value").text(""); //获取当前点击按钮的请假单数据,回填至显示项 var laf = $(this).data("laf"); $("#dname").text(laf.department_name); $("#name").text(laf.name); $("#startTime").text(formatDate(laf.start_time)); $("#endTime").text(formatDate(laf.end_time)); $("#reason").text(laf.reason); $("#formId").val(laf.form_id); //弹出layui对话框 layui.layer.open({ type : "1" , //页面层 title : "请假审批" , //标题 content : $("#divDialog") , //指定对话框容器对象 area : ["500px" , "400px"] , //尺寸 end : function(){ //销毁后触发事件 $("#divDialog").hide(); } }) }) /** * 提交审批数据 */ layui.form.on("submit(audit)" , function(data){ $.ajax({ url : "/leave/audit", //审核URL data : data.field , type : "post" , success: function (json) { //关闭所有layui对话框 layui.layer.closeAll(); //显示处理结果 if(json.code == "ok"){ swal({ type: 'success', html: "<h2>请假已审批完毕</h2>", confirmButtonText: "确定" }).then(function (result) { window.location.href="/forward/notice"; }); }else{ swal({ type: 'warning', html: "<h2>" + json.msg + "</h2>", confirmButtonText: "确定" }); } } }) return false; }) </script> </body> </html>
45
收起
正在回答 回答被采纳积分+1
2回答
java工程师2020版
- 参与学习 人
- 提交作业 9400 份
- 解答问题 16556 个
综合就业常年第一,编程排行常年霸榜,无需脱产即可学习,北上广深月薪过万 无论你是未就业的学生还是想转行的在职人员,不需要基础,只要你有梦想,想高薪
了解课程
恭喜解决一个难题,获得1积分~
来为老师/同学的回答评分吧
0 星