首页 » 技术分享 » 付款流程的付款单

付款流程的付款单

 

这是给房地产项目做报销流程时的填报报销单。报销单的所用到的知识有:

利用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' οnblur=\"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" οnchange="contract()">
<option value="">请选择</option>
<c:forEach items="${projectlist}" var="bean">
<option value="${bean.projectid}">${bean.projectname}</option>
</c:forEach>
</select> </td>
<td
style="height:28px; border:1px solid #b5d6e6; text-align:center;">合同信息:
<input type="text" name="contractname" id="contractname" readonly="readonly">
</td>  
<td
style="height:28px; border:1px solid #b5d6e6; text-align:center;">知情人/经办人
</td>
<td
style="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>
<td
style="height:28px; border:1px solid #b5d6e6; text-align:center;">名称</td>
<td
style="height:28px; border:1px solid #b5d6e6; text-align:center;">数量</td>
<td
style="height:28px; border:1px solid #b5d6e6; text-align:center;">单价</td>
<td
style="height:28px; border:1px solid #b5d6e6; text-align:center;">合计</td>
<td
style="height:28px; border:1px solid #b5d6e6; text-align:center;">
备注</td>
</tr>
<tr>
<td
style="height:28px; border:1px solid #b5d6e6; text-align:center;"><input
type="text" name="addlist[0].mc" id="mc0" />
</td>
<td
style="height:28px; border:1px solid #b5d6e6; text-align:center;"><input
type="text" name="addlist[0].sl" id="sl0" />
</td>
<td
style="height:28px; border:1px solid #b5d6e6; text-align:center;"><input
type="text" name="addlist[0].dj" id="dj0"
οnblur="jisuanzhi('0')">
</td>
<td
style="height:28px; border:1px solid #b5d6e6; text-align:center;"><input
type="text" name="addlist[0].hj" id="hj0" readonly="readonly">
</td>
<td
style="height:28px; border:1px solid #b5d6e6; text-align:center;"><input
type="text" name="addlist[0].bz" id="bz0">
</td>
</tr>
<tr>
</tr>
</table></td>
</tr>


<tr>
<td
style="height:28px; border:1px solid #b5d6e6; text-align:center;"
colspan="1">金额合计:<input type="text" id="zhj" name="zhj"
readonly="readonly" οnclick="sum()" /></td>
<td
style="height:28px; border:1px solid #b5d6e6; text-align:center;"
colspan="1">实际金额:<input type="text" id="reallypay"
name="reallypay" /></td>
<td
style="height:28px; border:1px solid #b5d6e6; text-align:center;"
colspan="3"><input type="button" id="bt1" value="增加行"
οnclick="add()" />       <input
type="button" id="bt1" value="减少行" οnclick="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);"><img
src="${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一个是付款单list
List<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