1.背景
1)本文只是简单记录下怎么使用operamasks-ui的omGrid进行增删改查,大部分代码可在operamasks-ui的demo看到;
2)前台使用freemarker模板,后台使用了Nutz框架;
2.先看下效果
3.前台代码编写
1)html
- <@m.mp title="测试1" jquery="jquery-1.7.min" css="test/default" js="test/test6/index">
- <@m.omui />
-
- <div style="margin-left:30px;margin-top:20px">
- <input type="button" id="add" value="新增"/>
- <input type="button" id="del" value="删除"/>
- <input type="button" id="save" value="保存修改"/>
- 姓名:<input id="qUserName"></input>
- <input id="query" type="button" value="查询"/>
- <table id="grid"></table>
- </div>
-
- </@m.mp>
其中的 <@m.mp> 是自己编写的标签库,用于生成页面主体
其中的 <@m.omui /> 是自己写的引入operamasks-ui的标签库,此标签的作用就是在页面上引入operamasks-ui所需的css和js文件。
2)css
- .om-grid div.bDiv tr.grayRow {
- background-color: gray;
- }
这里面根本就没什么内容。。。
3)js
主要演员都在这里了
- $(document).ready(function() {
-
- $.validator.addMethod("birthday", function(value) {
- return /^\d{4}年\d{2}月\d{2}日$/.test(value);
- }, '生日格式必须为 xxxx年xx月xx日');
-
- var genderOptions = {
- dataSource : [{text:"请选择",value:""},{text:"女生" , value:"female"},{text:"男生",value:"male"},{text:"未知",value:"unknowned"}],
- editable: false
- };
-
- var ageOptions = {
- allowDecimals:false,
- allowNegative:false
- };
-
- var birthdayOptions = {
-
- dateFormat : "yy-mm-dd H:i:s",
- showTime : true
- };
-
- $('#grid').omGrid({
- title : '表格',
- width: "90%",
- height:450,
- showIndex : false,
- singleSelect : true,
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- onRowClick : function(index,rowData,event){
- $('#grid').omGrid('editRow',index);
- },
- limit : 10,
- dataSource : 'test62.html',
- colModel : [ {header : 'ID', name : 'id', width : 100, align : 'center',sort:'clientSide',editor:{editable:false}},
- {header : '姓名', name : 'userName', width : 120, align : 'left',sort:'clientSide',
- editor:{
- rules:["required",true,"姓名是必填的"],
- type:"text",
- editable:true,
- name:"userName"
- }
- },
- {header : '密码', name : 'password', align : 'left',
- renderer : function(colValue, rowData, rowIndex) {
- if (colValue == '123456') {
- return '<span style="color:red;"><b>' + colValue + '</b></span>';
- } else if (colValue == "123A@wq") {
- return '<span style="color:green;"><b>' + colValue + '</b></span>';
- }
- return colValue;
- },
- editor:{
- rules:["required",true,"密码不能为空"],
- type:"text",
- editable:true,
- name:"password"
- }
- },
-
- {header : '出生日期', name : 'birthday', width : 180, align : 'left',sort:'clientSide',
-
-
-
- editor:{
-
- type:"omCalendar",
- editable:true,
- name:"birthday",
- options:birthdayOptions
- }
- }
- ]
-
-
- });
-
- $('#add').click(function(){
- $.ajax({
- type: "POST",
- url: "test65.html",
- async: false,
- dataType: "json",
- success: function(data){
- if(data.flag){
- $('#grid').omGrid('insertRow',0,{id:data.id});
- }
-
- }
- });
-
-
- });
-
- $('#del').click(function(){
- var dels = $('#grid').omGrid('getSelections');
- if(dels.length <= 0 ){
- alert('请选择删除的记录!');
- return;
- }
- $('#grid').omGrid('deleteRow',dels[0]);
- });
-
- $('#save').click(function(){
- var formData = $('#grid').omGrid('getChanges');
-
-
-
- var formDataStr = JSON.stringify(formData);
-
-
-
- $.ajax({
- type: "POST",
- url: "test64.html",
- data: {formData:formDataStr},
- async: false,
- dataType: "json",
- success: function(data){
- if(data){
- alert("保存成功");
- }
-
- }
- });
-
-
- $('#grid').omGrid('saveChanges');
-
- });
-
- $('#query').bind('click', function(e) {
- var qUserName=$('#qUserName').val();
- if(qUserName===""){
- $('#grid').omGrid("setData", 'test62.html');
- }else{
- $('#grid').omGrid("setData", 'test62.html?qUserName='+encodeURI(qUserName));
- }
- });
-
- });
从上往下依次是:验证、表格渲染、添加、删除、保存、查询
4.后台
1)显示列表,查询
看到列表渲染部分
- dataSource : 'test62.html'
调用了后台方法为 test62.html,后台代码:
-
-
-
- @At("/test62")
- @Ok("json")
- public GridDataModel<User> test62(){
- String startStr = getRequest().getParameter("start");
- String limitStr = getRequest().getParameter("limit");
- int start = Integer.parseInt(startStr);
- int limit = Integer.parseInt(limitStr);
- if(start==0){
- start=1;
- }
-
- Cnd cnd = null;
- String qUserName = getRequest().getParameter("qUserName");
- if(null != qUserName){
- cnd = Cnd.where("userName", "like", "%"+qUserName+"%");
- }
-
- int pagesize = (start/limit)+1;
- QueryResult qr = serviceManager.getUserService().query(cnd,pagesize,limit);
-
-
- GridDataModel<User> gdm = new GridDataModel<User>();
- gdm.setTotal(qr.getPager().getRecordCount());
- gdm.setRows((List<User>)qr.getList());
-
- return gdm;
- }
这里传给前台一个 GridDataModel 的 json 格式数据,GridDataModel 的代码:
- public class GridDataModel<T> {
-
- private int total;
-
- private List<T> rows = new ArrayList<T>();
-
- public List<T> getRows() {
- return rows;
- }
-
- public void setRows(List<T> rows) {
- this.rows = rows;
- }
-
- public int getTotal() {
- return total;
- }
-
- public void setTotal(int total) {
- this.total = total;
- }
-
- }
此方法是进入列表和查询功能
输入姓名点击查询就可以进行模糊查询:
2)删除
点击页面上的删除,只是调用了页面的omGrid进行删除行,没有去后台操作,要点击保存修改后才起作用
所以请看后面保存修改的代码。
3)新增
点击页面的新增,会调用:
先查看下源码:
-
-
-
- @At("/test65")
- @Ok("raw")
- public String test65(){
- String result = "";
- long maxId = serviceManager.getUserService().getMaxId();
- result = "{\"flag\":true,\"id\":" + (maxId+1) + "}";
- return result;
- }
获取user表的下一个ID;
为了简单,我自己手动拼了一个json数据返回到前台;
4)保存修改
前台调用了:
传的数据:
- var formData = $('#grid').omGrid('getChanges');
- var formDataStr = JSON.stringify(formData);
- ...
- data: {formData:formDataStr}
前台把json对象变成字符串传到后台,下面是后台代码:
-
-
-
- @At("/test64")
- @Ok("json")
- public boolean test64(){
- String formData = getRequest().getParameter("formData");
- log.debug("表格更改数据:" + formData);
- Map<String,Object> map = (Map<String,Object>)Json.fromJson(formData);
-
-
- List<Map<String,Object>> updateList = (List<Map<String,Object>>)map.get("update");
- List<User> uList = Json.fromJsonAsList(User.class, Json.toJson(updateList));
- for (int i = 0; i < uList.size(); i++) {
- serviceManager.getUserService().update(uList.get(i));
- }
-
-
- List<Map<String,Object>> insertList = (List<Map<String,Object>>)map.get("insert");
- uList = Json.fromJsonAsList(User.class, Json.toJson(insertList));
- for (int i = 0; i < uList.size(); i++) {
- serviceManager.getUserService().insert(uList.get(i));
- }
-
-
- List<Map<String,Object>> deleteList = (List<Map<String,Object>>)map.get("delete");
- uList = Json.fromJsonAsList(User.class, Json.toJson(deleteList));
- for (int i = 0; i < uList.size(); i++) {
- serviceManager.getUserService().delete(uList.get(i));
- }
-
- return true;
- }
===================================================
看了几天operamasks-ui,就写了这么点东西。。。