一.前端部分
創(chuàng)新互聯(lián)從2013年開始,先為鎮(zhèn)康等服務(wù)建站,鎮(zhèn)康等地企業(yè),進行企業(yè)商務(wù)咨詢服務(wù)。為鎮(zhèn)康企業(yè)網(wǎng)站制作PC+手機+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。
html只需要放一個有id的div就行了,方便js獲取渲染區(qū)域
js部分需要注意url為異步數(shù)據(jù)接口,done是渲染完表格之后的回調(diào)函數(shù)
table.render({ elem: '#data_grid' //,width: 900 //,height: 274 ,cols: [[ //標題欄 {field: 'id', title: 'ID', width: 80, sort: true} ,{field: 'username', title:'用戶名',width: 100} //空列 ,{field: 'password', title: '密碼', width: 120} ,{field: 'gender', title: '性別', width: 150} ,{field: 'nichen', title: '昵稱', width: 150} ,{field: 'birthday', title: '出生年月', width: 120} ,{fixed: 'right', width: 215,align:'center', toolbar: '#barDemo'} ]] ,url:url ,skin: 'row' //表格風格 ,even: true ,page: true //是否顯示分頁 ,limits: [3,5,10] ,limit: 5 //每頁默認顯示的數(shù)量 ,done:function(res){ userPage.data = res.data; } //,loading: false //請求數(shù)據(jù)時,是否顯示loading });
根據(jù)條件查詢,表格異步刷新,where為附帶參數(shù)
$('#sub_query_form').on('click',function () { var queryPo = page.formToJson($('#query_form').serialize()); var table = layui.table; table.reload('data_grid', { url: '/getUserList.action', page:{ curr:1 //從第一頁開始 }, method:'post', where:{ queryStr:queryPo }, done:function (res) { userPage.data = res.data; } }); });
將x-www-form-urlencoded轉(zhuǎn)化為json字符串
formToJson:function (data) { data=data.replace(/&/g,"\",\""); data=data.replace(/=/g,"\":\""); data="{\""+data+"\"}"; return data; }
表格工具欄使用
1.首先在html里定義好按鈕
2.js內(nèi)引用
layui.use('table', function(){ var table = layui.table; userPage.tab('/getUserList.action'); //監(jiān)聽工具條 table.on('tool(demo)', function(obj){ var data = obj.data; userPage.data = obj.data; if(obj.event === 'detail'){ layer.msg('ID:'+ data.id + ' 的查看操作'); } else if(obj.event === 'del'){ layer.confirm('真的要刪除這條記錄么',{icon: 3, title:'確定刪除'}, function(index){ obj.del(); $.post('/doDelete.action?id='+data.id,function (res) { userPage.reload(res); }); layer.close(index); }); } else if(obj.event === 'add'){ layer.open({ title:'增加窗口', content:userPage.template, yes:function () { var user = page.formToJson($('#layer_form').serialize()); var data = 'user='+user; $.post('/doAdd.action',data,function (res) { userPage.reload(res); }); layer.closeAll(); } }) } else if(obj.event === 'edit'){ layer.open({ title:'編輯窗口', content:userPage.template, success:function () { $('input[name="id"]').val(userPage.data.id); $('input[name="username"]').val(userPage.data.username); $('input[name="password"]').val(userPage.data.password); $('input[name="gender"]').val(userPage.data.gender); $('input[name="nichen"]').val(userPage.data.nichen); $('input[name="birthday"]').val(userPage.data.birthday); }, yes: function(){ var mgUser = page.formToJson($('#layer_form').serialize()); var data = 'user='+mgUser; $.post('/doEdit.action',data,function (res) { userPage.reload(res); }); layer.closeAll(); } }) } }); });
二.服務(wù)端部分
Controller層需要接收以下參數(shù),page,limit,要查詢的條件,返回值根據(jù)layui文檔給出的默認返回值
@RequestMapping("/getUserList") @ResponseBody public PageListgetUserList(@RequestParam(required = false,defaultValue = "1") int page,@RequestParam(required = false,defaultValue = "5") int limit,@RequestParam(required = false) String queryStr){ QueryPo queryPo = null; if (!StringUtils.isEmpty(queryStr)){ //性別類型轉(zhuǎn)換 queryPo = JSONObject.parseObject(queryStr,QueryPo.class); if ("1".equals(queryPo.getGender())){ queryPo.setGender("男"); } if ("2".equals(queryPo.getGender())){ queryPo.setGender("女"); } } PageList pageList = new PageList(); try { if (!StringUtils.isEmpty(queryPo)){ //中文字轉(zhuǎn)碼 if(!StringUtils.isEmpty(queryPo.getKeywords())){ queryPo.setKeywords(URLDecoder.decode(queryPo.getKeywords(),"utf-8")); } } List userList = userService.getUserList(page,limit,queryPo); //根據(jù)條件查詢分頁數(shù)據(jù) pageList.setCode("0"); pageList.setMsg("ok"); pageList.setData(userList); int count = userService.countUserByExample(queryPo); pageList.setCount(count); } catch (UnsupportedEncodingException e) { e.printStackTrace(); pageList.setCode("-1"); pageList.setMsg("數(shù)據(jù)獲取異常"); return pageList; } return pageList; }
Service層根據(jù)條件查詢并分頁
public ListgetUserList(int page , int limit, QueryPo queryPo) { MgUserExample userExample = new MgUserExample(); MgUserExample.Criteria criteria = userExample.createCriteria(); if(!StringUtils.isEmpty(queryPo)){ if (!StringUtils.isEmpty(queryPo.getGender())){ criteria.andGenderEqualTo(queryPo.getGender()); } if (!StringUtils.isEmpty(queryPo.getKeywords())){ criteria.andUsernameLike("%"+queryPo.getKeywords()+"%"); } } userExample.setStart((page-1)*limit); userExample.setLimit(limit); List mgUsers = userMapper.selectByExample(userExample); return mgUsers; }
注意由于mybatis逆向工程生成的Example沒有l(wèi)imit和page,所以需要自己加上
private int start; private int limit; public int getStart() { return start; } public void setStart(int start) { this.start = start; } public int getLimit() { return limit; } public void setLimit(int limit) { this.limit = limit; }
接著修改Mybatis的mapper.xml,需要加上分頁條件
以上就是layui實現(xiàn)數(shù)據(jù)表格及分頁的方法的詳細內(nèi)容,更多請關(guān)注創(chuàng)新互聯(lián)其它相關(guān)文章!