时间:2021-05-19
简单的页面分析
在上一个文章简单的数据库连接测试,已经测试和数据库做简单的交互,也就是dao层的实现,接下来要说的却是action的简单实现,在ssh中有struts作为表示层和server的交换,而这里我不是说的是关于struts这里只是简单的运用jsp的代码书写来实现数据的传输,这也是最繁琐的步骤,但是这却让我们对底层的调用有一个简单的了解,这里是直接调用封装好的数据,交换和使用,首先要书写的是action的使用,用的最多的就是getParameter表单的提交了,这里在网络上提交一个表单吗,然后通过getParameter进行获取,然后通过enployeeDao中的方法进行增删改查,就能够进行基本的逻辑操作了。
代码实现
<%@page import="dao.EmployeeDao"%><%@page import="java.text.SimpleDateFormat"%><%@page import="entity.Employee"%><%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%><!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html><head><meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"><title>Insert title here</title></head><body> <% //1、接收表单提交的参数 String action = request.getParameter("action"); //3.调用EmployeeDao中addEmployee(Employee employee)完成员工添加 EmployeeDao employeeDao = new EmployeeDao(); if (action.equals("0") || action.equals("1")) { //添加 更新 String empno = request.getParameter("empno"); String ename = request.getParameter("ename"); String sal = request.getParameter("sal"); String hiredate = request.getParameter("hiredate"); //2.将数据封装至Employee对象中 Employee employee = new Employee(); employee.setEmpno(Integer.parseInt(empno)); employee.setEname(ename); employee.setSal(Double.parseDouble(sal)); SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); employee.setHiredate(sdf.parse(hiredate)); if (action.equals("0")) { //添加 employeeDao.addEmployee(employee); } else { //更新 employeeDao.updateEmployee(employee); } } else if (action.equals("2")) { //删除 String empno = request.getParameter("empno"); employeeDao.deleteEmployee(empno); } else if (action.equals("3")) { //批量删除 System.out.println("action="+action); String[] chks=request.getParameterValues("chks"); for(String chk:chks){ System.out.println("chk="+chk); } } //4.画面跳转至employeeList.jsp 重定向 response.sendRedirect("employeeList.jsp"); %></body></html>然后我们进行简单的页面设计,运用了表格的形式进行设计,代码如下
<%@page import="java.util.List"%><%@page import="entity.Employee"%><%@page import="dao.EmployeeDao"%><%@page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%><!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html><head><meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"><title>Insert title here</title><script> function checkAll() { //1.获取chkAll的选中状态checked var chkAll = document.getElementById("chkAll"); //alert(chkAll.checked); //2、获取其他所有的checkbox var chks = document.getElementsByName("chks"); for (var i = 0; i < chks.length; i++) { //3、将chkAll的选中状态于其他checkbox的选中状态同步 chks[i].checked = chkAll.checked; } } function onDelete(empno){ var result=confirm("Delete Employee?"); if(result){ window.location.href="employeeManageAction.jsp?action=2&empno=" rel="external nofollow" +empno; } } //function onDeleteBatch(){ //判断是否有选中的checkbox //有选中的场合 //提示是否删除确认的信息 //确认删除 //提交表单 //var action=document.getElementById("action"); //action.value="3"; // document.frmlist.action="employeeManageAction.jsp" // document.frmlist.submit(); //取消删除 //不用处理 //无选中的场合 //提示选中记录的信息 //}</script></head><body> <h3>Employee List Page</h3> <form name="frmSearch" action="xxxxAction.jsp" method="post"> ename:<input type="text" /> <input type="submit" name="btnSubmit" value="submit" /> </form> <P> <hr /> <a href="employeeManage.jsp?action=0" rel="external nofollow" >Add Employee</a> <a href="javascript:void(0)" rel="external nofollow" rel="external nofollow" onclick="onDeleteBatch();">Delete Employee Batch</a> <P> <% EmployeeDao emplyeeDao = new EmployeeDao(); List<Employee> employees = emplyeeDao.getEmployees(); %> <% if (employees != null && employees.size() > 0) { %> <form name="frmlist" action="" method="post"> <input type="hidden" name="action" id="action" value="" /> <table width="600px" border="1px"> <tr bgcolor="#009966"> <td><input type="checkbox" id="chkAll" onclick="checkAll()" /></td> <td>empno</td> <td>ename</td> <td>sal</td> <td>hiredate</td> <td>action</td> </tr> <% Employee employee = null; for (int i = 0; i < employees.size(); i++) { employee = employees.get(i); %> <tr> <td><input type="checkbox" id="chk<%=i + 1%>" name="chks" value="<%=employee.getEmpno()%>" /></td> <td><%=employee.getEmpno()%></td> <td><%=employee.getEname()%></td> <td><%=employee.getSal()%></td> <td><%=employee.getHiredate()%></td> <td><a href="employeeManage.jsp?action=1&empno=<%=employee.getEmpno()%>" rel="external nofollow" >update</a> <a href="javascript:void(0)" rel="external nofollow" rel="external nofollow" onclick="onDelete(<%=employee.getEmpno()%>);">delete</a></td> </tr> <% } %> </table> </form> <% } %></body></html>接下来要说的是更新操作
<%@page import="entity.Employee"%><%@page import="dao.EmployeeDao"%><%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%><!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html><head><meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"><title>Insert title here</title><script> function checkForm() { var empno = document.getElementById("empno"); if (empno && empno.value == "") { empno.focus(); alert("please input empno"); return; } var ename = document.getElementById("ename"); if (ename && ename.value == "") { ename.focus(); alert("please input ename"); return; } var sal = document.getElementById("sal"); if (sal && sal.value == "") { sal.focus(); alert("please input sal"); return; } var hiredate = document.getElementById("hiredate"); if (hiredate && hiredate.value == "") { hiredate.focus(); alert("please input hiredate"); return; } var frm = document.getElementById("frm"); frm.submit(); }</script></head><body> <% String action=request.getParameter("action"); Employee employee=null; if(action.equals("1")){ //更新操作 String empno = request.getParameter("empno"); EmployeeDao employeeDao = new EmployeeDao(); employee=employeeDao.getEmployeeByEmpno(empno); } %> <h3>Employee <%=action.equals("1")?"Update":"Regist" %> Page</h3> <form id="frm" action="employeeManageAction.jsp" method="post" onsubmit="return checkForm();"> <input type="hidden" name="action" value="<%=action%>"/> <table> <tr> <td>empno</td> <td><input type="text" id="empno" name="empno" <%=action.equals("1")?"readOnly":"" %> value="<%=employee==null?"":employee.getEmpno()%>"/></td> </tr> <tr> <td>ename</td> <td><input type="text" id="ename" name="ename" value="<%=employee==null?"":employee.getEname()%>"/></td> </tr> <tr> <td>sal</td> <td><input type="text" id="sal" name="sal" value="<%=employee==null?"":employee.getSal()%>"/></td> </tr> <tr> <td>hiredate</td> <td><input type="text" id="hiredate" name="hiredate" value="<%=employee==null?"":employee.getHiredate()%>"/></td> </tr> <tr> <td><input type="button" name="btnSubmit" value="submit" onclick="checkForm();" /></td> <td><input type="reset" name="btnReset" value="reset" /></td> </tr> </table> </form></body></html>在这个过程中刚好用到了简单的js对数据进行非空和数据类型判断,这就是我们需要学会的逻辑,业务层,然后进行其他操作,当然我注释的是还没完成的多个删除和模糊搜索,这个下一个博客再去完善。
总结
在学习这个过程中,学会了更多关于数据调用的知识,而不是像hibernate那样在配置文件配置,然后直接调用就可以了,再用jsp中也发现jsp嵌入代码,更加笨重,这也是我学习的另一个方面吧。
更多学习资料请关注专题《管理系统开发》。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例为大家分享了JSP实现简单人事管理系统的具体代码,供大家参考,具体内容如下此系统使用jsp实现,其中包含了jsp九大内置对象和四大作用域的相关知识,采用
本文实例讲述了jsp+jdbc实现连接数据库的方法。分享给大家供大家参考。具体如下:初次尝试JSP+jdbc,按照书上的例子折腾了半天,就是连不上数据库。于是在
-数据分页显示-JDBC2.0:ODBC通过jdbc:odbc可以实现Jsp对数据库的操作,在这个例子中我将数据库的连接写在了一个JavaBean中,可以实现重
早期的项目比较简单,多是用JSP、Servlet+JDBC直接搞定,后来使用Struts1(Struts2)+Spring+Hibernate,严格按照分层概念
这是一个简易的员工管理系统,实现最简单的功能:1.登录用户密码验证(错误三次自动退出)2.支持文本员工的搜索、添加、删除、修改3.一级层级多个选项、二级层级多个