LayUI分页,LayUI动态分页,LayUI laypage分页,LayUI laypage刷新当前页
LayUI分页,LayUI动态分页,LayUI laypage分页,LayUI laypage刷新当前页
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
©Copyright 蕃薯耀 2017年8月1日
http://www.cnblogs.com/fanshuyao/
效果图:

一、引用js依赖
主要是jquery-1.11.3.min.js 和 layui.all.js , json2.js用来做json对象转换的
- <script type="text/javascript" src="${pageContext.request.contextPath}/js/jquery-1.11.3.min.js"></script>
- <script type="text/javascript" src="${pageContext.request.contextPath}/plugin/layui/lay/dest/layui.all.js"></script>
- <script type="text/javascript" src="${pageContext.request.contextPath}/js/json2.js"></script>
二、js分页方法封装(分页使用模板laytpl)
1、模板渲染
- /**
- * 分页模板的渲染方法
- * @param templateId 分页需要渲染的模板的id
- * @param resultContentId 模板渲染后显示在页面的内容的容器id
- * @param data 服务器返回的json对象
- */
- function renderTemplate(templateId, resultContentId, data){
- layui.use(['form','laytpl'], function(){
- var laytpl = layui.laytpl;
- laytpl($("#"+templateId).html()).render(data, function(html){
- $("#"+resultContentId).html(html);
- });
- });
- layui.form().render();// 渲染
- };
2、layui.laypage 分页封装
- /**
- * layui.laypage 分页封装
- * @param laypageDivId 分页控件Div层的id
- * @param pageParams 分页的参数
- * @param templateId 分页需要渲染的模板的id
- * @param resultContentId 模板渲染后显示在页面的内容的容器id
- * @param url 向服务器请求分页的url链接地址
- */
- function renderPageData(laypageDivId, pageParams, templateId, resultContentId, url){
- if(isNull(pageParams)){
- pageParams = {
- pageIndex : 1,
- pageSize : 10
- }
- }
- $.ajax({
- url : url,//basePath + '/sysMenu/pageSysMenu',
- method : 'post',
- data : pageParams,//JSON.stringify(datasub)
- async : true,
- complete : function (XHR, TS){},
- error : function(XMLHttpRequest, textStatus, errorThrown) {
- if("error"==textStatus){
- error("服务器未响应,请稍候再试");
- }else{
- error("操作失败,textStatus="+textStatus);
- }
- },
- success : function(data) {
- var jsonObj;
- if('object' == typeof data){
- jsonObj = data;
- }else{
- jsonObj = JSON.parse(data);
- }
- renderTemplate(templateId, resultContentId, jsonObj);
- //重新初始化分页插件
- layui.use(['form','laypage'], function(){
- laypage = layui.laypage;
- laypage({
- cont : laypageDivId,
- curr : jsonObj.pager.pageIndex,
- pages : jsonObj.pager.totalPage,
- skip : true,
- jump: function(obj, first){//obj是一个object类型。包括了分页的所有配置信息。first一个Boolean类,检测页面是否初始加载。非常有用,可避免无限刷新。
- pageParams.pageIndex = obj.curr;
- pageParams.pageSize = jsonObj.pager.pageSize;
- if(!first){
- renderPageData(laypageDivId, pageParams, templateId, resultContentId, url);
- }
- }
- });
- });
- }
- });
- };
3、刷新当前分页的方法,可省略
- /**
- * 分页插件刷新当前页的数据,必须有跳转的确定按钮,因为根据按钮点击事件刷新
- */
- function reloadCurrentPage(){
- $(".layui-laypage-btn").click();
- };
三、页面代码
1、分页表格及分页控件
- <!-- 分页表格 -->
- <div class="layui-form">
- <table class="layui-table">
- <thead>
- <tr>
- <th class="w20"><input type="checkbox" name="checkBoxAll" lay-skin="primary" lay-filter="allChoose"></th>
- <th class="w200">许可名称</th>
- <th class="w200">许可编码</th>
- <th class="w200">菜单名称</th>
- <th>许可链接</th>
- </tr>
- </thead>
- <tbody id="page_template_body_id">
- </tbody>
- </table>
- </div>
- <!-- 分页控件div -->
- <div id="imovie-page-div"></div>
2、分页模板
- <script id="page_template_id" type="text/html">
- {{# layui.each(d.list, function(index, item){ }}
- <tr>
- <td><input type="checkbox" name="permissionId" lay-skin="primary" value="{{item.permissionId}}"></td>
- <td>{{item.permissionName || ''}}</td>
- <td>{{item.permissionCode || ''}}</td>
- <td>{{item.menuName || ''}}</td>
- <td>{{item.permissionUrl || ''}}</td>
- </tr>
- {{# }); }}
- </script>
3、分页执行代码:
分页参数:
- function getPageParams(){
- var pageParams = {
- pageIndex : 1,
- pageSize : 2
- };
- pageParams.permissionName = $("input[name='permissionName']").val();
- pageParams.permissionCode = $("input[name='permissionCode']").val();
- pageParams.menuName = $("input[name='menuName']").val();
- return pageParams;
- };
分页执行方法:
- function initPage(){
- renderPageData("imovie-page-div", getPageParams(), "page_template_id",
- "page_template_body_id", basePath + '/sysPermission/pageSysPermission');
- };
页面加载初始化分页:
- $(function(){
- initPage();
- });
如果包括上面效果图的查询,如下:
Html页面代码
- <div>
- <form class="layui-form layui-form-pane">
- <div class="layui-form-item">
- <div class="layui-inline">
- <label class="layui-form-label">许可名称</label>
- <div class="layui-input-inline">
- <input type="text" name="permissionName"
- autocomplete="off" class="layui-input" placeholder="请输入许可名称" >
- </div>
- </div>
- <div class="layui-inline">
- <label class="layui-form-label">许可编码</label>
- <div class="layui-input-inline">
- <input type="text" name="permissionCode"
- autocomplete="off" placeholder="请输入许可编码" class="layui-input">
- </div>
- </div>
- <div class="layui-inline">
- <label class="layui-form-label">菜单名称</label>
- <div class="layui-input-inline layui-input-inline-0">
- <input type="text" name="menuName"
- autocomplete="off" placeholder="请选择菜单名称" class="layui-input">
- </div>
- </div>
- <div class="layui-inline">
- <button id="btnSubmit" class="layui-btn" lay-submit="" lay-filter="formFilter">查询</button>
- </div>
- </div>
- </form>
- </div>
查询语句:
- $(function(){
- initPage();
- layui.use(['form'], function(){
- var form = layui.form();
- //监听提交
- form.on('submit(formFilter)', function(data){
- initPage();
- return false;
- });
- });
- });
四、懂 jquery 插件封装的大神可以将其封装成独立的分页插件,这样更加容易使用。我表示不太懂,^_^
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
©Copyright 蕃薯耀 2017年8月1日
http://www.cnblogs.com/fanshuyao/
LayUI分页,LayUI动态分页,LayUI laypage分页,LayUI laypage刷新当前页的更多相关文章
- 在分页中,删除操作后,AJAX重载刷新当前页
需求 分页中,在 删除 和 编辑 完成后,AJAX重载刷新 当前页 ,而不是跳转到 第一页 实现步骤 添加两个的 input 控件,用来存储 当前页数 和 记录总条数(非必须,能有方法获取到这两个值即 ...
- layui 通过laytpl模板,以及laypage分页实现
一.引用js依赖 jquery-1.11.3.min.js , layui.all.js, json2.js 二.js分页方法封装(分页使用模板laytpl) 1.模板渲染 /** * 分页模板的渲 ...
- layui结合mybatis的pagehelper插件的分页通用的方法
总体思路: 1.前台查询的时候将当前页和页大小传到后台 2.后台将当前页,页大小以及数据与数据总数返回前台,前台显示完表格完数据之后显示分页插件. 前台页面: 准备查询条件的表单,与数据表格,分页di ...
- 拿来主义:layPage分页插件的使用
布衣之谈 所谓插件,大概就是项目中可插可拔的比较小功能化的组件:这些功能组件若能力可及,自己也可以完成——也即自己造轮子,但翻看各种技术社区,相关领域的神人们往往会有更好的实现方案贡献出来,这个时候你 ...
- 基于layui,Jquery 表格动态编辑 设置 编辑值为 int 或者 double 类型及默认值
首先先推荐大家在看这篇笔记时,阅读过我写的这篇 Layui表格编辑[不依赖Layui的动态table加载] 阅读过上面那篇笔记之后呢,才能更好的理解我现在所要说的这个东西 接下来废话不多说,上代码. ...
- 动态多条件查询分页以及排序(一)--MVC与Entity Framework版url分页版
一.前言 多条件查询分页以及排序 每个系统里都会有这个的代码 做好这块 可以大大提高开发效率 所以博主分享下自己的6个版本的 多条件查询分页以及排序 二.目前状况 不论是ado.net 还是EF ...
- laypage分页控件使用方法
laypage是一款非常简单易用的分页控件,由于最近项目中使用到了,简单记录一下使用方法 1.引入laypage所需的js和css文件 <link href="js/laypage/1 ...
- easyui combogrid下拉表格的分页/按键/动态搜索
作者:xfl4629712 < easyui combogrid下拉表格的分页/按键/动态搜索 > 需求: 1.下拉框下拉时出现表格: 2.表格带分页功能: 3.可以使用向上键.向下 ...
- SPA项目开发之动态树+数据表格+分页
SPA项目开发之动态树+数据表格+分页 动态生成NavMenu导航菜单(只支持2级菜单) <el-menu key="" index=""> < ...
随机推荐
- 《学习OpenCV3》第7章第4题-SVD奇异值分解的验算
原文题目: 中文翻译: 解题过程 d.使用OpenCV编写代码 , , , , ,); Mat A = static_cast< ...
- EntityFramework Core映射关系详解
前言 Hello,开始回归开始每周更新一到两篇博客,本节我们回归下EF Core基础,来讲述EF Core中到底是如何映射的,废话少说,我们开始. One-Many Relationship(一对多关 ...
- dubbo与zookeeper的关系
Dubbo建议使用Zookeeper作为服务的注册中心. 1. Zookeeper的作用: zookeeper用来注册服务和进行负载均衡,哪一个服务由哪一个机器来提供必需让调用者知道,简单来说就是 ...
- 限制input[type=number]的输入位数策略整理
当我们使用类型number的input输入框的时候,我们可能需要限制输入的位数,这个时候通常会想到maxlength,但是maxlength是在number类型的时候是不支持的,下面是一些解决这种问题 ...
- System.Runtime.Serialization.SerializationException”类型的未经处理的异常在 System.Runtime.Serialization.dll 中发生
异常信息: “System.Runtime.Serialization.SerializationException”类型的未经处理的异常在 System.Runtime.Serialization. ...
- 一起学习c++11——c++11中的新增的容器
c++11新增的容器1:array array最早是在boost中出现:http://www.boost.org/doc/libs/1_61_0/doc/html/array.html 当时的初衷是希 ...
- [leetcode-581-Shortest Unsorted Continuous Subarray]
Given an integer array, you need to find one continuous subarray that if you only sort this subarray ...
- pdf.js在国际化的时候,显示不了中文的解决办法
在项目中使用了pdf实现在线预览功能,开始工具栏中一直都是英文的,在view.js中设置了也不起作用,偶然发现了问题所在 当我把网站发布到iis上的时候,用google浏览器的审查元素功能的审核发现j ...
- css 背景图片自适应
body{ height:100%; overflow:hidden;} .bg { background-image: url(../../img/beijing.jpg); width:100%; ...
- Socket实现-Socket I/O
Socket层的核心是两个函数:sosend()和soreceive().这两个函数负责处理所有Socket层和协议层之间的I/O操作. select()系统调用的作用是监控文件描述符的状态.一般用于 ...