前端弹出审批对话框未显示后端传回的json
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 | 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); } } |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 | <!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版
- 参与学习 人
- 提交作业 9404 份
- 解答问题 16556 个
综合就业常年第一,编程排行常年霸榜,无需脱产即可学习,北上广深月薪过万 无论你是未就业的学生还是想转行的在职人员,不需要基础,只要你有梦想,想高薪
了解课程
恭喜解决一个难题,获得1积分~
来为老师/同学的回答评分吧