亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

laypage+SpringMVC實現后端分頁

2024-05-06 16:53:44
字體:
來源:轉載
供稿:網友

項目中用到了模板引擎thymeleaf和前端框架layUI,算是一路摸索、一個坑一個坑踩過來的。之前邊學習邊做項目的時候沒有記錄下學習的過程和遇到問題的解決思路和方法,著實有點可惜。所以從現在開始咯。

laypage分頁

下面就以laypage的兩種分頁展開行文的思路:異步刷新分頁和整頁刷新式跳轉。具體可參看官方文檔。

異步刷新分頁

首先使用laypage之前,先加載laypage模塊。使用 layui.use(‘laypage')加載即可。

1.前端html代碼如下:

<div id="log-list"></div><div id="page-list"></div>

2.JS代碼如下:

這部分使用了laypage分頁函數和jQuery的append函數,實現異步刷新。

function paging(curr){  $.getJSON('/page', {  page: curr || 1 //向服務端傳的參數  }, function(res){   //此處輸出內容   var table = $("<table></table>");   table.attr({class:"layui-table admin-table",id:"page"});   var thead = $("<thead><tr><th>編號</th><th>姓名</th><th>行為</th><th>時間</th><th>操作</th></tr></thead>");   table.append(thead);   var tbody = $("<tbody></tbody>");   tbody.attr({id:"content"});   $(function(){    var datas = res;     $.each(datas,function(index,value){     var tr = $("<tr></tr>");     tr.append("<td>"+ (++index) + "</td>");      tbody.append(tr);      tr.append("<td>"+ value.staffName + "</td>");      tbody.append(tr);      tr.append("<td>"+ value.operation + "</td>");      tbody.append(tr);      tr.append("<td>"+ value.createTime + "</td>");      tbody.append(tr);      var td = $("<td></td>");      var div = $("<div></div>");      div.attr({class:"layui-btn-group"});      var button1 = $("<button detailId=" + value.weeklyId +">詳情</button>");      button1.attr({class:"layui-btn detail"});      var button2 = $("<button recoveryId=" + value.weeklyId +">恢復</button>");      button2.attr({class:"layui-btn recovery"});      div.append(button1);div.append(button2);      td.append(div);      tr.append(td);      tbody.append(tr);     });     });   table.append(tbody);   $("#log-list").append(table);  // $("#log-list").innerHTML = table;  //顯示分頁  laypage({   cont: 'page-list', //容器。值支持id名、原生dom對象,jquery對象?!救缭撊萜鳛椤浚?lt;div id="page1"></div>   pages: res[0].pageTotal, //通過后臺拿到的總頁數   curr: curr || 1, //當前頁   skip: true,   jump: function(obj, first){ //觸發分頁后的回調   if(!first){ //點擊跳頁觸發函數自身,并傳遞當前頁:obj.curr    $("#log-list").text('');    paging(obj.curr);   }   }  });  }); }; //運行 paging();

實現以上代碼,基本上的樣式已經出來。下面執行實現后端分頁和數據查詢即可。/p>

3.后端代碼–controller部分:

/**  * 功能描述:返回無查詢條件查詢分頁數據  * @param page  * @return  * @since   */ @RequestMapping(value="/page") @ResponseBody public List<SubmitLog> getPage(Integer page){  if(page == null){   page = 1;  }  List<SubmitLog> submitLogList = new ArrayList<>();  submitLogList = logService.getAllLog(page);  return submitLogList; }

4.后端代碼–service部分:

/**  * 功能描述 :無查詢條件分頁  * @param pageCurr  * @return  * @since   */ public List<SubmitLog> getAllLog(int pageCurr){  int pageSize = 10;//每頁顯示十條數據  int pageStart = (pageCurr - 1) * pageSize;// limit=(pageCurr -1)*10,10  List<SubmitLog> submitLogList = new ArrayList<>();  submitLogList = logMapper.getAllLog(pageSize, pageStart);  //計算前端頁面顯示的頁數//  當前數據庫記錄數  int count = submitLogList.get(0).getPageTotal();  int page = count%pageSize == 0 ? count/pageSize : count/pageSize + 1;  log.debug("頁數"+page);  submitLogList.get(0).setPageTotal(page);  return submitLogList; }

5.后端代碼–dao部分:

/**  * 功能描述:查詢所有數據--帶分頁  * @param pageSize 每頁大小  * @param pageCurr 即將顯示當前頁  * @return  * @since   */ @Select("SELECT s.pageTotal,number_id,staff_name,create_time,weekly_id,operation FROM submit_log,"   + "(SELECT count(1) AS pageTotal FROM submit_log) s ORDER BY number_id DESC LIMIT #{pageStart},#{pageSize}") @Results({  @Result(column="number_id",property="numberId"),  @Result(column="staff_name",property="staffName"),  @Result(column="create_time",property="createTime"),  @Result(column="weekly_id",property="weeklyId") }) List<SubmitLog> getAllLog(@Param("pageSize") int pageSize,@Param("pageStart") int pageStart );

至此,異步分頁前后端結合基本結束,因為代碼都帶有必要的注釋,所以也無需過多解釋。

整頁刷新式跳轉

這種方式的分頁,基本上分頁邏輯都由laypage去實現了,后端分頁邏輯基本上不用過多考慮。還是比較方便的,建議結合官網的文檔和代碼進行理解。下面是實現代碼:

1.前端HTML代碼:

//此處是顯示數據的具體HTML代碼<div id="page-list"></div> //分頁顯示的位置

2.Js代碼:

這部分的分頁實現,后端只需返回總頁數即可。

function paging(){   $.getJSON('/weekly-page-count',{},function(res){    //整頁刷新    laypage({     cont: 'page-list',     pages: res, //可以叫服務端把總頁數放在某一個隱藏域,再獲取。假設我們獲取到的是18     curr: function(){ //通過url獲取當前頁,也可以同上(pages)方式獲取     var page = location.search.match(/page=(/d+)/);     return page ? page[1] : 1;     }(),      skip: true,     jump: function(e, first){ //觸發分頁后的回調     if(!first){ //一定要加此判斷,否則初始時會無限刷新      location.href = '?page='+e.curr;     }     }    });   });  }  paging();

3.后端代碼–controller部分:

/**  * 功能描述:返回無查詢條件查詢分頁數--用戶  * @param page  * @return  * @since   */ @RequestMapping(value="/weekly-page-count") @ResponseBody public Integer getPage1(Integer userId){  Integer count = weeklyService.getPageCount(userId);  return count; }

4.后端代碼–service部分:

/**  * 功能描述:總頁數  * @param userId  * @return  * @since   */ public Integer getPageCount(Integer userId){  int count = 0;  count = weeklyMapper.getPageCount(userId);  int pageSize = 5; //每頁顯示條數  int page = count%pageSize == 0 ? count/pageSize : count/pageSize + 1; //計算頁數  return page; }

5.后端代碼–dao部分:

/**  * 功能描述:無條件查詢記錄條數==分頁總數  * @param userId  * @return  * @since   */ @Select("SELECT count(1) AS pageTotal FROM weekly WHERE user_id = #{userId}") Integer getPageCount(@Param("userId") Integer userId);

總結:兩種分頁方式使用起來都是比較方便的。使用的場景還是有些不同:異步式適合JQuery重寫頁面比較容易的;整頁式更簡單,各種場景都可以使用。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美丝袜一区二区三区| 69国产精品成人在线播放| 亚洲国产精品一区二区久| 精品精品国产国产自在线| 日韩av成人在线观看| 亚洲天堂成人在线视频| 国产亚洲精品激情久久| 日韩精品中文字幕有码专区| 久久久精品在线观看| 国产啪精品视频网站| 色综合导航网站| 久久中文字幕在线| 日产精品久久久一区二区福利| 亚洲美女av在线| 国产91在线播放精品91| 久久中文精品视频| 亚洲精品欧美日韩专区| 国模私拍视频一区| 亚洲成人久久久久| 成人一区二区电影| 国产日韩精品在线观看| 亚洲国产精品中文| 亚洲国产精品va| 97超级碰碰人国产在线观看| 亚州国产精品久久久| 夜夜嗨av色一区二区不卡| 欧美电影免费观看电视剧大全| 欧美野外wwwxxx| 中文字幕亚洲一区二区三区五十路| 日韩欧美视频一区二区三区| 精品偷拍一区二区三区在线看| 国产午夜精品全部视频播放| 亚洲女人初尝黑人巨大| 亚洲精品久久久久| 在线精品高清中文字幕| 欧美精品精品精品精品免费| 亚洲欧美成人一区二区在线电影| 欧美精品少妇videofree| 精品国产一区二区在线| 成人免费在线网址| 成人444kkkk在线观看| 91国产视频在线| 国产成人免费av电影| 久久影视电视剧凤归四时歌| 国产精品激情av电影在线观看| 97久久久免费福利网址| 国产精品视频自在线| 国产精品免费久久久| 日本亚洲欧洲色| 亚洲综合中文字幕在线| 欧美老女人www| 91免费电影网站| 久久亚洲电影天堂| 最新91在线视频| 亚洲国产欧美一区二区三区久久| 韩国三级日本三级少妇99| 伦理中文字幕亚洲| 国产国语videosex另类| 欧美日韩免费在线| 国产免费观看久久黄| 久久视频在线视频| 国产一区视频在线| 疯狂欧美牲乱大交777| zzjj国产精品一区二区| 欧美日韩中文在线观看| 欧美日韩999| 午夜精品久久久久久99热软件| 久久精品视频中文字幕| 欧美在线影院在线视频| 亚洲第一av在线| 欧美激情综合亚洲一二区| 国产一区二区黑人欧美xxxx| 97久久精品在线| 久久亚洲欧美日韩精品专区| 69国产精品成人在线播放| 久久99精品视频一区97| 国模gogo一区二区大胆私拍| 久久久久久国产精品| 欧美中文字幕在线观看| 日韩一区二区福利| 国产亚洲福利一区| 欧美国产精品va在线观看| 日韩精品久久久久久福利| 日本高清视频精品| 久久久久久久久久久av| 日本久久精品视频| 亚洲一区二区日本| 欧美成人黑人xx视频免费观看| 在线观看精品国产视频| 最好看的2019年中文视频| 欧美激情精品久久久| 日韩精品亚洲精品| 久久青草精品视频免费观看| 自拍偷拍亚洲精品| 久久艹在线视频| 欧美精品videosex极品1| 欧美韩国理论所午夜片917电影| 超薄丝袜一区二区| 亚洲一区二区三区777| 日韩视频一区在线| 日韩中文字幕久久| 亚洲区中文字幕| 青草成人免费视频| 久久久免费观看视频| 国产91色在线| 成人精品一区二区三区电影免费| 亚洲精品视频免费在线观看| 尤物yw午夜国产精品视频| 国产精品免费看久久久香蕉| 欧美xxxx综合视频| 亚洲精品国产精品自产a区红杏吧| 日韩中文字幕视频| 国产精品黄色av| 久久精品国产亚洲精品2020| 欧美精品xxx| 欧洲日本亚洲国产区| 国产精品 欧美在线| 国产一区二区欧美日韩| 亚洲自拍小视频| 亚洲精品黄网在线观看| 国产在线日韩在线| 91精品国产综合久久香蕉922| 国产一区玩具在线观看| 亚洲国产欧美一区二区三区同亚洲| 亚洲香蕉伊综合在人在线视看| 久久精品视频中文字幕| 亚洲第一网站免费视频| 在线免费看av不卡| 超薄丝袜一区二区| 欧美亚洲成人xxx| 在线观看不卡av| 91大神在线播放精品| 国产日韩专区在线| 国产精品免费久久久| www.欧美精品一二三区| 亚洲资源在线看| 国产999精品久久久影片官网| 亚洲a级在线播放观看| 国产成人精品久久亚洲高清不卡| 欧美一级免费视频| 久久久99免费视频| 欧美性理论片在线观看片免费| 91精品国产高清久久久久久91| 中文字幕在线观看日韩| 日韩麻豆第一页| 欧美午夜宅男影院在线观看| 亚洲影视中文字幕| 国产精品v片在线观看不卡| 亚洲人免费视频| 国产成人精品综合| 萌白酱国产一区二区| 亚洲精品国产精品久久清纯直播| 久久香蕉国产线看观看av| 亚洲欧美日韩爽爽影院| 国内精品久久久久影院 日本资源| 蜜臀久久99精品久久久久久宅男| 国产精品美乳一区二区免费| 亚洲www永久成人夜色| 亚洲一级黄色av| 国产精品久久久久影院日本| 亚洲精品一区二区三区婷婷月| 日韩电影免费观看中文字幕| 日韩欧美成人免费视频| 在线观看日韩av|