付款流程的付款单

来源:互联网 发布:全钢oa网络防静电地板 编辑:程序博客网 时间:2024/04/28 21:11

这是给房地产项目做报销流程时的填报报销单。报销单的所用到的知识有:利用jquery计算合计值,给另一个文本框直接赋值,利用script增减行信息,显示和隐藏下拉框,利用json向后台传递信息。其中选择项目信息时,利用json向后台查询是否有本项目对应的合同信息。<img src="" alt="" />付款单jsp页面:<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%><%@ include file="/WEB-INF/jsp/public/common.jspf"%><html><head><title>报销信息</title><script type="text/javascript">function contract(){ var projectid=$("#projectid").val();      $.ajax({           type:"POST",                          url:"<%=request.getContextPath()%>/paymentAction_getContract.action?projectid="+ projectid,  dataType : "json",  timeout : 8000,success : function(data) {$("#contractname").val("");var objs = eval(data);if(objs.length>0){$("#contractname").val(objs[0].name);}else{$("#contractname").val("没有对应的合同信息");}},error : function() {$("#contractname").val("没有对应的合同信息");}});}</script><script type="text/javascript">num = 1;//记录行数function add() {//增加行var tr = document.createElement('tr');var td = document.createElement('td');td.innerHTML = "<td ><input type='text' id='mc"+num+"' name='addlist["+num+"].mc'></td>";tr.appendChild(td);td = document.createElement('td');td.innerHTML = "<td ><input type='text' id='sl"+num+"' name='addlist["+num+"].sl'></td>";tr.appendChild(td);td = document.createElement('td');td.innerHTML = "<td ><input type='text' id='dj" + num+ "' name='addlist[" + num + "].dj' onblur=\"jisuanzhi('" + num+ "')\"></td>";tr.appendChild(td);td = document.createElement('td');td.innerHTML = "<td ><input type='text' id='hj"+num+"' name='addlist["+num+"].hj' readonly='readonly'></td>";tr.appendChild(td);td = document.createElement('td');td.innerHTML = "<td ><input type='text' id='bz"+num+"' name='addlist["+num+"].bz'></td>";tr.appendChild(td);var dct = document.getElementById("table");dct.tBodies[0].appendChild(tr);++num;};function del() {//删除一行var i = document.getElementById("table").rows.length;if (i < 3) {alert("不能再删除了!!");} else {num--;document.getElementById("table").deleteRow(i - 1);}};function sum() {//计算总金额var zhjje = 0;for ( var i = 1; i <= num; i++) {var hj = document.getElementById("hj" + (i - 1) + "").value;//取出每行合计的值zhjje = parseFloat(zhjje) + parseFloat(hj);}zhjje = Math.round(zhjje * 100) / 100;$("#zhj").val(zhjje);}</script><script type="text/javascript">function jisuanzhi(num) {var sl = document.getElementById("sl" + num + "").value;var dj = document.getElementById("dj" + num + "").value;if (isNaN(sl)) {alert("'数量'的格式不对,应该输入数字!");}if (isNaN(dj)) {alert("'单价'的格式不对,应该输入数字!");}if (!isNaN(sl) && !isNaN(dj)) {$("#hj" + num + "").val(Math.round(sl * dj * 100) / 100);}}</script><style type="text/css">.tab {border: none;border-collapse: collapse;}td {height: 28px;border: 1px solid #b5d6e6;text-align: center;}</style></head><body><!-- 标题显示 --><div id="Title_bar"><div id="Title_bar_Head"><div id="Title_Head"></div><div id="Title"><!--页面标题--><img border="0" width="13" height="13"src="${pageContext.request.contextPath}/style/images/title_arrow.gif" />报销申请信息</div><div id="Title_End"></div></div></div><!--显示表单内容--><div id=MainArea><div class="ItemBlock_Title1" style=" margin-left:50px;"><!-- 信息说明 --><div class="ItemBlock_Title1"><img border="0" width="4" height="7"src="${pageContext.request.contextPath}/style/blue/images/item_point.gif" />付款申请信息</div></div><div class="ItemBlock" style=" margin-left:-50px; "><s:form action="flowAction_paymentsubmit" method="post" id="myForm"><table style=" border:none; border-collapse:collapse; width:100%;"><tr><td style="height:28px; border:1px solid #b5d6e6; text-align:center;">报销依据</td><td style="height:28px; border:1px solid #b5d6e6; text-align:center;">项目:<selectid="projectid" name="projectid" onchange="contract()"><option value="">请选择</option><c:forEach items="${projectlist}" var="bean"><option value="${bean.projectid}">${bean.projectname}</option></c:forEach></select> </td><tdstyle="height:28px; border:1px solid #b5d6e6; text-align:center;">合同信息:<input type="text" name="contractname" id="contractname" readonly="readonly"></td>  <tdstyle="height:28px; border:1px solid #b5d6e6; text-align:center;">知情人/经办人</td><tdstyle="height:28px; border:1px solid #b5d6e6; text-align:center;"><input type="text" name="jbr" /></td></tr><tr><td colspan="5"style="height:28px; border:1px solid #b5d6e6; text-align:center;"><table id="table"style=" border:none; border-collapse:collapse; width:100%;"><tr><tdstyle="height:28px; border:1px solid #b5d6e6; text-align:center;">名称</td><tdstyle="height:28px; border:1px solid #b5d6e6; text-align:center;">数量</td><tdstyle="height:28px; border:1px solid #b5d6e6; text-align:center;">单价</td><tdstyle="height:28px; border:1px solid #b5d6e6; text-align:center;">合计</td><tdstyle="height:28px; border:1px solid #b5d6e6; text-align:center;">备注</td></tr><tr><tdstyle="height:28px; border:1px solid #b5d6e6; text-align:center;"><inputtype="text" name="addlist[0].mc" id="mc0" /></td><tdstyle="height:28px; border:1px solid #b5d6e6; text-align:center;"><inputtype="text" name="addlist[0].sl" id="sl0" /></td><tdstyle="height:28px; border:1px solid #b5d6e6; text-align:center;"><inputtype="text" name="addlist[0].dj" id="dj0"onblur="jisuanzhi('0')"></td><tdstyle="height:28px; border:1px solid #b5d6e6; text-align:center;"><inputtype="text" name="addlist[0].hj" id="hj0" readonly="readonly"></td><tdstyle="height:28px; border:1px solid #b5d6e6; text-align:center;"><inputtype="text" name="addlist[0].bz" id="bz0"></td></tr><tr></tr></table></td></tr><tr><tdstyle="height:28px; border:1px solid #b5d6e6; text-align:center;"colspan="1">金额合计:<input type="text" id="zhj" name="zhj"readonly="readonly" onclick="sum()" /></td><tdstyle="height:28px; border:1px solid #b5d6e6; text-align:center;"colspan="1">实际金额:<input type="text" id="reallypay"name="reallypay" /></td><tdstyle="height:28px; border:1px solid #b5d6e6; text-align:center;"colspan="3"><input type="button" id="bt1" value="增加行"onclick="add()" />       <inputtype="button" id="bt1" value="减少行" onclick="del()" /></td></tr></table><div id="InputDetailBar"><input type="image"src="${pageContext.request.contextPath}/style/blue/images/button/submit.PNG" /><a href="javascript:history.go(-1);"><imgsrc="${pageContext.request.contextPath}/style/images/goBack.png" /></a></div></s:form></div></div></body>json根据项目查询合同信息时的controller:@Controller@Scope("prototype")public class PaymentAction extends BaseAction{private String projectid;public String getProjectid() {return projectid;}public void setProjectid(String projectid) {this.projectid = projectid;}/** 合同申请添加页面 */private HttpServletResponse response;public String paymentaddUI() throws Exception {List<Project> projectlist=projectService.findAllexit();//查找登录人员的角色有没有员工或部门主管的角色User user=getCurrentUser();Set<Role> userolelist = user.getRoles();Iterator<Role> it = userolelist.iterator();boolean flag = false;while (it.hasNext()) {Role str = it.next();if (str.getName() .contains("员工")||str.getName().contains("主管")) {flag = true;break;}}if(flag == true){// 准备数据List<ProcessDefinition> processDefinitionList = processDefinitionService.findAllLatestVersions();ActionContext.getContext().put("processDefinitionList", processDefinitionList);ActionContext.getContext().put("projectlist", projectlist);return "paymentaddUI";}else{return "errorUI";}}public void getContract()throws Exception{response=ServletActionContext.getResponse();response.setCharacterEncoding("UTF-8");        StringBuffer sb=new StringBuffer();        sb.append("[");        long id=Long.parseLong(projectid);        List<Contract> contractlist=contractService.Byprojectid(id);        for(int i=0;i<contractlist.size();i++){        Contract contract = new Contract();        contract = (Contract) contractlist.get(i);sb.append("{\"id\":"+contract.getContractid()+",\"name\":\""+contract.getContractname()+"\"},");} sb.deleteCharAt(sb.length()-1);sb.append("]");        String str=sb.toString();        System.out.println(str+"************str");            PrintWriter out = null;response.setCharacterEncoding("UTF-8");// 指定返回值的编码方式,必须放在out声明之前response.setContentType("text/html;charset=UTF-8");try {out = response.getWriter();out.print(str);out.flush();} catch (IOException e) {e.printStackTrace();} finally {out.close();}}public HttpServletResponse getResponse() {return response;}public void setResponse(HttpServletResponse response) {this.response = response;}}表单提交的controller:要接收多条的付款明细信息,用一个对象list、来接收。一个是报销单list一个是付款单listList<NormalreimbursementMX> addList;List<PaymentMX> addlist;public List<PaymentMX> getAddlist() {return addlist;}public void setAddlist(List<PaymentMX> addlist) {this.addlist = addlist;}public String paymentsubmit() throws Exception{SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");Date date=new Date();String timestamp=sdf.format(date)+System.currentTimeMillis();Payment payment=new Payment();PrintData printData=new PrintData();printData.setTimestamp(timestamp);normalreimbursementService.saveprintData(printData);//将财务出纳用到的保存下来payment.setJbr(jbr);payment.setContractname(contractname);payment.setProjectid(projectid);payment.setTimestamp(timestamp);payment.setZhj(zhj);payment.setReallypay(reallypay);paymentService.save(payment);for(int i=0;i<addlist.size();i++){PaymentMX paymentmx=new PaymentMX(); paymentmx=addlist.get(i);paymentmx.setTimestamp(timestamp);paymentMXService.save(paymentmx);}Application appcation=new Application();appcation.setApplicant(getCurrentUser());appcation.setTimestamp(timestamp);appcation.setProcessDefinitionKey("付款流程");applicationService.submit(appcation);return "toMyApplicationList";}



json传多个参数到后台的方法:

 $.ajax({
   type:"post",
   url:"leaveApplicationAction_getleaveday.action",
   data: {leastart:leastart,leastartam:leastartam,leaend:leaend,leaenspm:leaenspm},
   
timeout : 4000,
success : function(data) {
    var objs = eval(data);

if(objs.length>0){
$("#leavedays").val(objs[0].tianshu);
}

},
error : function() {
alert("与服务器连接超时...");
}
});
}
}


/**
* 新建用户输入是否重复登录名
*/
public   void checkLoginName() {
String str = "";

// 查询
User user = userService.getByLoginName(loginNameS);

if (user != null) {

str="{\"success\":true,\"message\":\"error\"}";
addFieldError("loginName", "登录名重复,请重新填写!");


//return "loginUI";
} else {

str="{\"success\":true,\"message\":\"success\"}";


//return "toIndex";
}
AjaxPrint.stringPrint(str);

}

function  Checklogin(){


var loginName=$("#loginName").val();


$.ajax({
type:"post",
url:"userAction_checkLoginName.action",
data:{loginNameS:loginName},
timeout:2000,
dataType:'json',
success:function(data){
var str=data.message;

if(str=='error'){
alert("登录名重复!");
$("#loginName").val("");

}
}
});
}

0 0
原创粉丝点击