BOS项目6:业务受理功能、快速录入工作单、{datagrid数据表格编辑功能使用}

本文主要是介绍BOS项目6:业务受理功能、快速录入工作单、{datagrid数据表格编辑功能使用},希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!



目录

  1. 1    业务受理部分需求分析
  2. 2    根据pdm导出sql脚本文件
  3. 3    业务受理功能实现
  4. 4    数据表格编辑功能使用
  5. 5    实现工作单快速录入功能基于datagrid编辑

1.    业务受理部分需求分析

整个BOS项目分为:基础设置、取派、中转、路由、报表。

受理功能为整个取派的一部分

受理环节,是物流业务的开始,作为服务前端,客户通过电话、网络等多种方式进行委托,业务受理员通过与客户交流,获取客户的服务需求和具体委托信息,将服务指令输入我司服务系统。

    业务通知单:客户通过打电话方式进行物流委托,物流公司业务人员将委托信息录入到bos系统中------业务通知单

    工单:业务人员将业务通知单信息录入到系统后,BOS系统会尝试根据客户的取件地址自动找到取派员,为取派员产生一个取货的任务-----工单

    工作单:取派员将货物从客户住处取回物流公司,将货物的相关信息(寄件人信息、收件人信息)录入到bos系统中------工作单

2.    根据pdm导出sql脚本文件


3.    业务受理功能实现

3.1   在crm系统中扩展方法---根据手机号查询客户信息

注意:需要将CustomerService接口中扩展的方法复制到bos接口中

3.2   在业务受理页面调整

业务受理页面:

目的:通过电话号码字段触发丢失焦点发送ajax查询此手机号的相关用户信息回显到当前表单

 

    为“来电号码”输入框绑定离焦事件

[javascript]  view plain  copy
 
  在CODE上查看代码片 派生到我的代码片
  1. <td>来电号码:</td>  
  2. <td><input type="text" class="easyui-validatebox" name="telephone"  
  3.     required="true" />  
  4.     <script>  
  5.         $(function(){  
  6.             //为“来电号码”绑定离焦事件  
  7.             $("input[name=telephone]").blur(function(){  
  8.                 //发送ajax请求,请求Action,在action中调用代理对象,通过代理对象远程调用crm  
  9.                 var url = "${pageContext.request.contextPath}/noticebillAction_findCustomerByPhone.action";  
  10.                 $.post(url,{"telephone":this.value},function(data){  
  11.                     if(data != null){  
  12.                         //将客户信息回显到相应的输入框中  
  13.                         var id = data.id;  
  14.                         var name = data.name;  
  15.                         var address = data.address;  
  16.                         $("input[name=customerId]").val(id);  
  17.                         $("input[name=customerName]").val(name);  
  18.                         $("input[name=delegater]").val(name);  
  19.                         $("input[name=pickaddress]").val(address);  
  20.                     }else{  
  21.                         $("input[name=customerId]").val("");  
  22.                         $("input[name=customerName]").val("");  
  23.                         $("input[name=delegater]").val("");  
  24.                         $("input[name=pickaddress]").val("");  
  25.                     }  
  26.                 });  
  27.             });  
  28.         });  
  29.     </script>  

    创建一个NoticebillAction,注入Customerservice代理对象,提供方法findCustomerByPhone

[java]  view plain  copy
 
  在CODE上查看代码片 派生到我的代码片
  1. //注入代理对象,调用crm服务  
  2. @Resource  
  3. private CustomerService customerService;  
  4.   
  5. /** 
  6.  * 根据手机号查询客户信息 
  7.  */  
  8. public String findCustomerByPhone(){  
  9.     //调用crm服务  
  10.     Customer customer = customerService.findCustomerByPhone(model.getTelephone());  
  11.     this.writeObjectBean2Json(customer, new String[]{});  
  12.     return NONE;  
  13. }  

配置struts.xml

    提交表单

[javascript]  view plain  copy
 
  在CODE上查看代码片 派生到我的代码片
  1. <script type="text/javascript">  
  2.     $(function(){  
  3.         $("body").css({visibility:"visible"});  
  4.           
  5.         // 对save按钮条件 点击事件  
  6.         $('#save').click(function(){  
  7.             // 对form 进行校验  
  8.             if($('#noticebillForm').form('validate')){  
  9.                 $('#noticebillForm').submit();  
  10.             }  
  11.         });  
  12.     });  
  13. </script>  

    在action中接受参数,保存业务通知单

保存业务通知单:通过判断用户所关联的定区id 来进行自动分单或手动分单

[java]  view plain  copy
 
  在CODE上查看代码片 派生到我的代码片
  1. /** 
  2.  * 保存业务通知单 
  3.  */  
  4. public String add(){  
  5.     noticebillService.save(model);  
  6.     return "toAddUI";  
  7. }  

Service代码:

[java]  view plain  copy
 
  在CODE上查看代码片 派生到我的代码片
  1. @Service  
  2. @Transactional  
  3. public class NoticebillServiceImpl implements INoticebillService{  
  4.     @Resource  
  5.     private INoticebillDao noticebillDao;  
  6.     //注入代理对象  
  7.     @Resource  
  8.     private CustomerService customerService;  
  9.     @Resource  
  10.     private IDecidedzoneDao decidedzoneDao;  
  11.     @Resource  
  12.     private IWorkbillDao workbillDao;  
  13.       
  14.     public void save(Noticebill model) {  
  15.         User user = BOSContext.getLoginUser();  
  16.         model.setUser(user);//当前登录用户  
  17.         noticebillDao.save(model);//持久对象  
  18.           
  19.         //自动分单----为当前客户找到一个取派员,取件  
  20.         //取件地址  
  21.         String pickaddress = model.getPickaddress();  
  22.         //根据取件地址获取定区ID  
  23.         String decidedzoneId = customerService.findDecidedzoneidByPickAddress(pickaddress);  
  24.         if(decidedzoneId != null){  
  25.             model.setOrdertype("自动");  
  26.             //匹配成功,可以自动分单  
  27.             Decidedzone decidedzone = decidedzoneDao.findById(decidedzoneId);  
  28.             Staff staff = decidedzone.getStaff();//获得定区的负责人  
  29.               
  30.             model.setStaff(staff);//建立业务通知单和取派员关系  
  31.               
  32.             //为当前匹配到取派员产生一个工单  
  33.             Workbill workbill = new Workbill();  
  34.             workbill.setNoticebill(model);//关联业务通知单  
  35.             workbill.setStaff(staff);//关联取派员  
  36.             workbill.setType("新");//类型  
  37.             workbill.setPickstate("未取件");//取件状态  
  38.             workbill.setBuildtime(new Timestamp(System.currentTimeMillis()));//系统时间  
  39.             workbill.setAttachbilltimes(0);//追单次数  
  40.             workbill.setRemark(model.getRemark());//备注  
  41.             //保存工单  
  42.             workbillDao.save(workbill);  
  43.               
  44.             //调用短信接口向取派员发送短信  
  45.               
  46.         }else{  
  47.             //匹配失败,转入人工分单  
  48.             model.setOrdertype("人工");  
  49.         }  
  50.           
  51.     }  
  52. }  

4.    数据表格编辑功能使用

    使用datagrid的[列属性]开启编辑功能

editor      

属性值类型:string,object      

详情:

指明编辑类型。当字符串指明编辑类型的时候,对象包含2个属性:

type:字符串,该编辑类型可以使用的类型有:text,textarea,checkbox,numberbox,validatebox,datebox,combobox,combotree。

options:对象,object, 该编辑器属性对应于编辑类型。

    开始编辑和结束编辑[方法]

beginEdit       参数:index     开始编辑行。

endEdit           参数:index     结束编辑行。

    插入一行数据

insertRow       

详情:

插入一个新行,参数包括一下属性:

index:要插入的行索引,如果该索引值未定义,则追加新行。

row:行数据。

    获得行索引

getRowIndex  

参数row

返回指定行的索引号,该行的参数可以是一行记录或一个ID字段值。

 

    删除行

deleteRow      index      删除行。

 

    结束编辑状态时触发的[事件]

onAfterEdit    

参数:rowIndex,rowData, changes  

详情:

在用户完成编辑一行的时候触发,参数包括:

rowIndex:编辑行的索引,索引从0开始。

rowData:对应于完成编辑的行的记录。

changes:更改后的字段(键)/值对。

示例

[javascript]  view plain  copy
 
  在CODE上查看代码片 派生到我的代码片
  1. <script type="text/javascript">  
  2.     $(function() {  
  3.         var index = -1;  
  4.         $("#grid").datagrid({  
  5.             columns : [ [ {  
  6.                 field : 'id',  
  7.                 checkbox : true,  
  8.             }, {  
  9.                 field : 'name',  
  10.                 title : '姓名',  
  11.                 width : 120,  
  12.                 align : 'center',  
  13.                 editor : {  
  14.                     type : 'validatebox',  
  15.                     options : {  
  16.                         required : true  
  17.                     }  
  18.                 }  
  19.             }, {  
  20.                 field : 'telephone',  
  21.                 title : '手机号',  
  22.                 width : 120,  
  23.                 align : 'center',  
  24.                 editor : {  
  25.                     type : 'validatebox',  
  26.                     options : {  
  27.                         required : true  
  28.                     }  
  29.                 }  
  30.             } ] ],  
  31.             //事件:结束编辑状态时触发  
  32.             onAfterEdit:function(rowIndex, rowData, changes){  
  33.                 //发送ajax请求,将数据提交到服务端修改数据库  
  34.             },  
  35.             url : '${pageContext.request.contextPath}/json/staff.json',  
  36.                 toolbar : [ {  
  37.                                 id : 'button-add',  
  38.                                 text : '增加一行',  
  39.                                 iconCls : 'icon-add',  
  40.                                 handler : function(){  
  41.                                     $("#grid").datagrid("insertRow",{//插入一行  
  42.                                         index:0,//在第一行插入  
  43.                                         row:{}//空行  
  44.                                     });  
  45.                                     index = 0;  
  46.                                     //开启第一行的编辑状态  
  47.                                     $("#grid").datagrid("beginEdit",index);//开启第一行编辑状态  
  48.                                 }  
  49.                             }, //按钮  
  50.                             {  
  51.                                 id : 'button-save',  
  52.                                 text : '保存',  
  53.                                 iconCls : 'icon-save',  
  54.                                 handler : function(){  
  55.                                     //结束编辑状态  
  56.                                     $("#grid").datagrid("endEdit",index);//开启第一行编辑状态  
  57.                                 }  
  58.                             },  
  59.                             {  
  60.                                 id : 'button-eidt',  
  61.                                 text : '编辑',  
  62.                                 iconCls : 'icon-save',  
  63.                                 handler : function(){  
  64.                                     var rows = $("#grid").datagrid("getSelections");  
  65.                                     if(rows.length == 1){  
  66.                                         //获得当前选中行的索引  
  67.                                         index = $("#grid").datagrid("getRowIndex",rows[0]);  
  68.                                         $("#grid").datagrid("beginEdit",index);  
  69.                                     }  
  70.                                 }  
  71.                             }  
  72.                         ]  
  73.         });  
  74.     });  
  75. </script>  
  76. </head>  
  77. <body>  
  78.     <table id="grid"></table>  
  79. </body>  

5.    实现工作单快速录入功能(基于datagrid编辑)

页面:


按钮

[javascript]  view plain  copy
 
  在CODE上查看代码片 派生到我的代码片
  1. //行数全局变量  
  2. var editIndex ;  
  3. //添加按钮  
  4. function doAdd(){  
  5.     //当填完一行数据(一个工作单)后不点保存直接点击下增加一行  
  6.     if(editIndex != undefined){  
  7.         //根据全局变量完成上次的编辑  
  8.         $("#grid").datagrid('endEdit',editIndex);  
  9.     }  
  10.     //新增一行  
  11.     if(editIndex==undefined){  
  12.         //alert("快速添加电子单...");  
  13.         $("#grid").datagrid('insertRow',{  
  14.             index : 0,//第一行  
  15.             row : {}//添加一排空行  
  16.         });  
  17.         //开启新增行的编辑  
  18.         $("#grid").datagrid('beginEdit',0);  
  19.         editIndex = 0;  
  20.     }  
  21. }  
  22. //保存按钮  
  23. function doSave(){  
  24.     //结束编辑  
  25.     $("#grid").datagrid('endEdit',editIndex );  
  26. }  
  27.   
  28. function doCancel(){  
  29.     if(editIndex!=undefined){  
  30.         $("#grid").datagrid('cancelEdit',editIndex);  
  31.         if($('#grid').datagrid('getRows')[editIndex].id == undefined){  
  32.             $("#grid").datagrid('deleteRow',editIndex);  
  33.         }  
  34.         editIndex = undefined;  
  35.     }  
  36. }  

    修改datagrid的事件onAfterEdit

[javascript]  view plain  copy
 
  在CODE上查看代码片 派生到我的代码片
  1. // 收派标准数据表格  
  2. $('#grid').datagrid( {  
  3.     iconCls : 'icon-forward',  
  4.     fit : true,  
  5.     border : true,  
  6.     rownumbers : true,  
  7.     striped : true,  
  8.     pageList: [30,50,100],  
  9.     pagination : true,  
  10.     toolbar : toolbar,  
  11.     url :  "",  
  12.     idField : 'id',  
  13.     columns : columns,  
  14.     onDblClickRow : doDblClickRow,  
  15.     onAfterEdit : function(rowIndex, rowData, changes){  
  16.         console.info(rowData);  
  17.         editIndex = undefined;  
  18.         //发送ajax请求保存工作单  
  19.         var url="${pageContext.request.contextPath}/workordermanageAction_quickAdd";  
  20.         $.post(url,rowData,function(data){  
  21.             //alert(data);  
  22.             if(data=='1'){  
  23.                 $.messager.alert("提示","添加成功","info");  
  24.             }else{  
  25.                 $.messager.alert("错误提示","添加失败","warning");  
  26.             }  
  27.         });  
  28.     }  
  29. });  

    创建WorkordermanageAction

[java]  view plain  copy
 
  在CODE上查看代码片 派生到我的代码片
  1. /** 
  2.  * ajax 工作单快速添加 
  3.  * @return 
  4.  * @throws IOException  
  5.  */  
  6. public String quickAdd() throws IOException{  
  7.     // 添加更新时间  
  8.     this.getModel().setUpdatetime(new Date());  
  9.     String flag="0";  
  10.     try {  
  11.         workordermanageService.quickAdd(this.getModel());  
  12.     } catch (Exception e) {  
  13.         flag= "1";  
  14.         e.printStackTrace();  
  15.     }  
  16.     //相应通知  
  17.     ServletActionContext.getResponse().setContentType("text/html;charset=utf-8");  
  18.     ServletActionContext.getResponse().getWriter().print(flag);  
  19.     return NONE;  
  20. }  

    配置struts.xml

目录(?)[-]

  1. 1    业务受理部分需求分析
  2. 2    根据pdm导出sql脚本文件
  3. 3    业务受理功能实现
  4. 4    数据表格编辑功能使用
  5. 5    实现工作单快速录入功能基于datagrid编辑

1.    业务受理部分需求分析

整个BOS项目分为:基础设置、取派、中转、路由、报表。

受理功能为整个取派的一部分

受理环节,是物流业务的开始,作为服务前端,客户通过电话、网络等多种方式进行委托,业务受理员通过与客户交流,获取客户的服务需求和具体委托信息,将服务指令输入我司服务系统。

    业务通知单:客户通过打电话方式进行物流委托,物流公司业务人员将委托信息录入到bos系统中------业务通知单

    工单:业务人员将业务通知单信息录入到系统后,BOS系统会尝试根据客户的取件地址自动找到取派员,为取派员产生一个取货的任务-----工单

    工作单:取派员将货物从客户住处取回物流公司,将货物的相关信息(寄件人信息、收件人信息)录入到bos系统中------工作单

2.    根据pdm导出sql脚本文件


3.    业务受理功能实现

3.1   在crm系统中扩展方法---根据手机号查询客户信息

注意:需要将CustomerService接口中扩展的方法复制到bos接口中

3.2   在业务受理页面调整

业务受理页面:

目的:通过电话号码字段触发丢失焦点发送ajax查询此手机号的相关用户信息回显到当前表单

 

    为“来电号码”输入框绑定离焦事件

[javascript]  view plain  copy
 
  在CODE上查看代码片 派生到我的代码片
  1. <td>来电号码:</td>  
  2. <td><input type="text" class="easyui-validatebox" name="telephone"  
  3.     required="true" />  
  4.     <script>  
  5.         $(function(){  
  6.             //为“来电号码”绑定离焦事件  
  7.             $("input[name=telephone]").blur(function(){  
  8.                 //发送ajax请求,请求Action,在action中调用代理对象,通过代理对象远程调用crm  
  9.                 var url = "${pageContext.request.contextPath}/noticebillAction_findCustomerByPhone.action";  
  10.                 $.post(url,{"telephone":this.value},function(data){  
  11.                     if(data != null){  
  12.                         //将客户信息回显到相应的输入框中  
  13.                         var id = data.id;  
  14.                         var name = data.name;  
  15.                         var address = data.address;  
  16.                         $("input[name=customerId]").val(id);  
  17.                         $("input[name=customerName]").val(name);  
  18.                         $("input[name=delegater]").val(name);  
  19.                         $("input[name=pickaddress]").val(address);  
  20.                     }else{  
  21.                         $("input[name=customerId]").val("");  
  22.                         $("input[name=customerName]").val("");  
  23.                         $("input[name=delegater]").val("");  
  24.                         $("input[name=pickaddress]").val("");  
  25.                     }  
  26.                 });  
  27.             });  
  28.         });  
  29.     </script>  

    创建一个NoticebillAction,注入Customerservice代理对象,提供方法findCustomerByPhone

[java]  view plain  copy
 
  在CODE上查看代码片 派生到我的代码片
  1. //注入代理对象,调用crm服务  
  2. @Resource  
  3. private CustomerService customerService;  
  4.   
  5. /** 
  6.  * 根据手机号查询客户信息 
  7.  */  
  8. public String findCustomerByPhone(){  
  9.     //调用crm服务  
  10.     Customer customer = customerService.findCustomerByPhone(model.getTelephone());  
  11.     this.writeObjectBean2Json(customer, new String[]{});  
  12.     return NONE;  
  13. }  

配置struts.xml

    提交表单

[javascript]  view plain  copy
 
  在CODE上查看代码片 派生到我的代码片
  1. <script type="text/javascript">  
  2.     $(function(){  
  3.         $("body").css({visibility:"visible"});  
  4.           
  5.         // 对save按钮条件 点击事件  
  6.         $('#save').click(function(){  
  7.             // 对form 进行校验  
  8.             if($('#noticebillForm').form('validate')){  
  9.                 $('#noticebillForm').submit();  
  10.             }  
  11.         });  
  12.     });  
  13. </script>  

    在action中接受参数,保存业务通知单

保存业务通知单:通过判断用户所关联的定区id 来进行自动分单或手动分单

[java]  view plain  copy
 
  在CODE上查看代码片 派生到我的代码片
  1. /** 
  2.  * 保存业务通知单 
  3.  */  
  4. public String add(){  
  5.     noticebillService.save(model);  
  6.     return "toAddUI";  
  7. }  

Service代码:

[java]  view plain  copy
 
  在CODE上查看代码片 派生到我的代码片
  1. @Service  
  2. @Transactional  
  3. public class NoticebillServiceImpl implements INoticebillService{  
  4.     @Resource  
  5.     private INoticebillDao noticebillDao;  
  6.     //注入代理对象  
  7.     @Resource  
  8.     private CustomerService customerService;  
  9.     @Resource  
  10.     private IDecidedzoneDao decidedzoneDao;  
  11.     @Resource  
  12.     private IWorkbillDao workbillDao;  
  13.       
  14.     public void save(Noticebill model) {  
  15.         User user = BOSContext.getLoginUser();  
  16.         model.setUser(user);//当前登录用户  
  17.         noticebillDao.save(model);//持久对象  
  18.           
  19.         //自动分单----为当前客户找到一个取派员,取件  
  20.         //取件地址  
  21.         String pickaddress = model.getPickaddress();  
  22.         //根据取件地址获取定区ID  
  23.         String decidedzoneId = customerService.findDecidedzoneidByPickAddress(pickaddress);  
  24.         if(decidedzoneId != null){  
  25.             model.setOrdertype("自动");  
  26.             //匹配成功,可以自动分单  
  27.             Decidedzone decidedzone = decidedzoneDao.findById(decidedzoneId);  
  28.             Staff staff = decidedzone.getStaff();//获得定区的负责人  
  29.               
  30.             model.setStaff(staff);//建立业务通知单和取派员关系  
  31.               
  32.             //为当前匹配到取派员产生一个工单  
  33.             Workbill workbill = new Workbill();  
  34.             workbill.setNoticebill(model);//关联业务通知单  
  35.             workbill.setStaff(staff);//关联取派员  
  36.             workbill.setType("新");//类型  
  37.             workbill.setPickstate("未取件");//取件状态  
  38.             workbill.setBuildtime(new Timestamp(System.currentTimeMillis()));//系统时间  
  39.             workbill.setAttachbilltimes(0);//追单次数  
  40.             workbill.setRemark(model.getRemark());//备注  
  41.             //保存工单  
  42.             workbillDao.save(workbill);  
  43.               
  44.             //调用短信接口向取派员发送短信  
  45.               
  46.         }else{  
  47.             //匹配失败,转入人工分单  
  48.             model.setOrdertype("人工");  
  49.         }  
  50.           
  51.     }  
  52. }  

4.    数据表格编辑功能使用

    使用datagrid的[列属性]开启编辑功能

editor      

属性值类型:string,object      

详情:

指明编辑类型。当字符串指明编辑类型的时候,对象包含2个属性:

type:字符串,该编辑类型可以使用的类型有:text,textarea,checkbox,numberbox,validatebox,datebox,combobox,combotree。

options:对象,object, 该编辑器属性对应于编辑类型。

    开始编辑和结束编辑[方法]

beginEdit       参数:index     开始编辑行。

endEdit           参数:index     结束编辑行。

    插入一行数据

insertRow       

详情:

插入一个新行,参数包括一下属性:

index:要插入的行索引,如果该索引值未定义,则追加新行。

row:行数据。

    获得行索引

getRowIndex  

参数row

返回指定行的索引号,该行的参数可以是一行记录或一个ID字段值。

 

    删除行

deleteRow      index      删除行。

 

    结束编辑状态时触发的[事件]

onAfterEdit    

参数:rowIndex,rowData, changes  

详情:

在用户完成编辑一行的时候触发,参数包括:

rowIndex:编辑行的索引,索引从0开始。

rowData:对应于完成编辑的行的记录。

changes:更改后的字段(键)/值对。

示例

[javascript]  view plain  copy
 
  在CODE上查看代码片 派生到我的代码片
  1. <script type="text/javascript">  
  2.     $(function() {  
  3.         var index = -1;  
  4.         $("#grid").datagrid({  
  5.             columns : [ [ {  
  6.                 field : 'id',  
  7.                 checkbox : true,  
  8.             }, {  
  9.                 field : 'name',  
  10.                 title : '姓名',  
  11.                 width : 120,  
  12.                 align : 'center',  
  13.                 editor : {  
  14.                     type : 'validatebox',  
  15.                     options : {  
  16.                         required : true  
  17.                     }  
  18.                 }  
  19.             }, {  
  20.                 field : 'telephone',  
  21.                 title : '手机号',  
  22.                 width : 120,  
  23.                 align : 'center',  
  24.                 editor : {  
  25.                     type : 'validatebox',  
  26.                     options : {  
  27.                         required : true  
  28.                     }  
  29.                 }  
  30.             } ] ],  
  31.             //事件:结束编辑状态时触发  
  32.             onAfterEdit:function(rowIndex, rowData, changes){  
  33.                 //发送ajax请求,将数据提交到服务端修改数据库  
  34.             },  
  35.             url : '${pageContext.request.contextPath}/json/staff.json',  
  36.                 toolbar : [ {  
  37.                                 id : 'button-add',  
  38.                                 text : '增加一行',  
  39.                                 iconCls : 'icon-add',  
  40.                                 handler : function(){  
  41.                                     $("#grid").datagrid("insertRow",{//插入一行  
  42.                                         index:0,//在第一行插入  
  43.                                         row:{}//空行  
  44.                                     });  
  45.                                     index = 0;  
  46.                                     //开启第一行的编辑状态  
  47.                                     $("#grid").datagrid("beginEdit",index);//开启第一行编辑状态  
  48.                                 }  
  49.                             }, //按钮  
  50.                             {  
  51.                                 id : 'button-save',  
  52.                                 text : '保存',  
  53.                                 iconCls : 'icon-save',  
  54.                                 handler : function(){  
  55.                                     //结束编辑状态  
  56.                                     $("#grid").datagrid("endEdit",index);//开启第一行编辑状态  
  57.                                 }  
  58.                             },  
  59.                             {  
  60.                                 id : 'button-eidt',  
  61.                                 text : '编辑',  
  62.                                 iconCls : 'icon-save',  
  63.                                 handler : function(){  
  64.                                     var rows = $("#grid").datagrid("getSelections");  
  65.                                     if(rows.length == 1){  
  66.                                         //获得当前选中行的索引  
  67.                                         index = $("#grid").datagrid("getRowIndex",rows[0]);  
  68.                                         $("#grid").datagrid("beginEdit",index);  
  69.                                     }  
  70.                                 }  
  71.                             }  
  72.                         ]  
  73.         });  
  74.     });  
  75. </script>  
  76. </head>  
  77. <body>  
  78.     <table id="grid"></table>  
  79. </body>  

5.    实现工作单快速录入功能(基于datagrid编辑)

页面:


按钮

[javascript]  view plain  copy
 
  在CODE上查看代码片 派生到我的代码片
  1. //行数全局变量  
  2. var editIndex ;  
  3. //添加按钮  
  4. function doAdd(){  
  5.     //当填完一行数据(一个工作单)后不点保存直接点击下增加一行  
  6.     if(editIndex != undefined){  
  7.         //根据全局变量完成上次的编辑  
  8.         $("#grid").datagrid('endEdit',editIndex);  
  9.     }  
  10.     //新增一行  
  11.     if(editIndex==undefined){  
  12.         //alert("快速添加电子单...");  
  13.         $("#grid").datagrid('insertRow',{  
  14.             index : 0,//第一行  
  15.             row : {}//添加一排空行  
  16.         });  
  17.         //开启新增行的编辑  
  18.         $("#grid").datagrid('beginEdit',0);  
  19.         editIndex = 0;  
  20.     }  
  21. }  
  22. //保存按钮  
  23. function doSave(){  
  24.     //结束编辑  
  25.     $("#grid").datagrid('endEdit',editIndex );  
  26. }  
  27.   
  28. function doCancel(){  
  29.     if(editIndex!=undefined){  
  30.         $("#grid").datagrid('cancelEdit',editIndex);  
  31.         if($('#grid').datagrid('getRows')[editIndex].id == undefined){  
  32.             $("#grid").datagrid('deleteRow',editIndex);  
  33.         }  
  34.         editIndex = undefined;  
  35.     }  
  36. }  

    修改datagrid的事件onAfterEdit

[javascript]  view plain  copy
 
  在CODE上查看代码片 派生到我的代码片
  1. // 收派标准数据表格  
  2. $('#grid').datagrid( {  
  3.     iconCls : 'icon-forward',  
  4.     fit : true,  
  5.     border : true,  
  6.     rownumbers : true,  
  7.     striped : true,  
  8.     pageList: [30,50,100],  
  9.     pagination : true,  
  10.     toolbar : toolbar,  
  11.     url :  "",  
  12.     idField : 'id',  
  13.     columns : columns,  
  14.     onDblClickRow : doDblClickRow,  
  15.     onAfterEdit : function(rowIndex, rowData, changes){  
  16.         console.info(rowData);  
  17.         editIndex = undefined;  
  18.         //发送ajax请求保存工作单  
  19.         var url="${pageContext.request.contextPath}/workordermanageAction_quickAdd";  
  20.         $.post(url,rowData,function(data){  
  21.             //alert(data);  
  22.             if(data=='1'){  
  23.                 $.messager.alert("提示","添加成功","info");  
  24.             }else{  
  25.                 $.messager.alert("错误提示","添加失败","warning");  
  26.             }  
  27.         });  
  28.     }  
  29. });  

    创建WorkordermanageAction

[java]  view plain  copy
 
  在CODE上查看代码片 派生到我的代码片
  1. /** 
  2.  * ajax 工作单快速添加 
  3.  * @return 
  4.  * @throws IOException  
  5.  */  
  6. public String quickAdd() throws IOException{  
  7.     // 添加更新时间  
  8.     this.getModel().setUpdatetime(new Date());  
  9.     String flag="0";  
  10.     try {  
  11.         workordermanageService.quickAdd(this.getModel());  
  12.     } catch (Exception e) {  
  13.         flag= "1";  
  14.         e.printStackTrace();  
  15.     }  
  16.     //相应通知  
  17.     ServletActionContext.getResponse().setContentType("text/html;charset=utf-8");  
  18.     ServletActionContext.getResponse().getWriter().print(flag);  
  19.     return NONE;  
  20. }  

    配置struts.xml

这篇关于BOS项目6:业务受理功能、快速录入工作单、{datagrid数据表格编辑功能使用}的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/369137

相关文章

详解Vue如何使用xlsx库导出Excel文件

《详解Vue如何使用xlsx库导出Excel文件》第三方库xlsx提供了强大的功能来处理Excel文件,它可以简化导出Excel文件这个过程,本文将为大家详细介绍一下它的具体使用,需要的小伙伴可以了解... 目录1. 安装依赖2. 创建vue组件3. 解释代码在Vue.js项目中导出Excel文件,使用第三

Linux alias的三种使用场景方式

《Linuxalias的三种使用场景方式》文章介绍了Linux中`alias`命令的三种使用场景:临时别名、用户级别别名和系统级别别名,临时别名仅在当前终端有效,用户级别别名在当前用户下所有终端有效... 目录linux alias三种使用场景一次性适用于当前用户全局生效,所有用户都可调用删除总结Linux

java图像识别工具类(ImageRecognitionUtils)使用实例详解

《java图像识别工具类(ImageRecognitionUtils)使用实例详解》:本文主要介绍如何在Java中使用OpenCV进行图像识别,包括图像加载、预处理、分类、人脸检测和特征提取等步骤... 目录前言1. 图像识别的背景与作用2. 设计目标3. 项目依赖4. 设计与实现 ImageRecogni

Java中Springboot集成Kafka实现消息发送和接收功能

《Java中Springboot集成Kafka实现消息发送和接收功能》Kafka是一个高吞吐量的分布式发布-订阅消息系统,主要用于处理大规模数据流,它由生产者、消费者、主题、分区和代理等组件构成,Ka... 目录一、Kafka 简介二、Kafka 功能三、POM依赖四、配置文件五、生产者六、消费者一、Kaf

Python将大量遥感数据的值缩放指定倍数的方法(推荐)

《Python将大量遥感数据的值缩放指定倍数的方法(推荐)》本文介绍基于Python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处理,并将所得处理后数据保存为新的遥感影像... 本文介绍基于python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处

python管理工具之conda安装部署及使用详解

《python管理工具之conda安装部署及使用详解》这篇文章详细介绍了如何安装和使用conda来管理Python环境,它涵盖了从安装部署、镜像源配置到具体的conda使用方法,包括创建、激活、安装包... 目录pytpshheraerUhon管理工具:conda部署+使用一、安装部署1、 下载2、 安装3

Mysql虚拟列的使用场景

《Mysql虚拟列的使用场景》MySQL虚拟列是一种在查询时动态生成的特殊列,它不占用存储空间,可以提高查询效率和数据处理便利性,本文给大家介绍Mysql虚拟列的相关知识,感兴趣的朋友一起看看吧... 目录1. 介绍mysql虚拟列1.1 定义和作用1.2 虚拟列与普通列的区别2. MySQL虚拟列的类型2

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

关于@MapperScan和@ComponentScan的使用问题

《关于@MapperScan和@ComponentScan的使用问题》文章介绍了在使用`@MapperScan`和`@ComponentScan`时可能会遇到的包扫描冲突问题,并提供了解决方法,同时,... 目录@MapperScan和@ComponentScan的使用问题报错如下原因解决办法课外拓展总结@

mysql数据库分区的使用

《mysql数据库分区的使用》MySQL分区技术通过将大表分割成多个较小片段,提高查询性能、管理效率和数据存储效率,本文就来介绍一下mysql数据库分区的使用,感兴趣的可以了解一下... 目录【一】分区的基本概念【1】物理存储与逻辑分割【2】查询性能提升【3】数据管理与维护【4】扩展性与并行处理【二】分区的