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=""> < ...
随机推荐
- Java并发编程之synchronized
在Java编程中,为了保证线程安全,有3种不同的思路1.互斥同步:包括synchronized和lock等. 2.非阻塞同步:如AtomicInteger的increaseAndGet()方法等. 3 ...
- 高性能队列Disruptor系列3--Disruptor的简单使用(译)
简单用法 下面以一个简单的例子来看看Disruptor的用法:生产者发送一个long型的消息,消费者接收消息并打印出来. 首先,我们定义一个Event: public class LongEvent ...
- CSS常用Hack集合(adding)
1> IE9 and IE10 @media screen and (min-width: 0\0) { .p-form input.p-value[type="checkbox&qu ...
- 【JavaScript学习】-JS内置对象3-String对象
定义: 定义字符串的方法就是直接赋值,例如:var mystr="Javascript is good!"; 访问字符串的属性: length属性 eg:var myl=mystr ...
- 论文笔记 Generative Face Completion
这篇paper将巧妙地将四个loss函数结合在一起,其中每一个loss的功能不同.但这篇paper不够elegant的地方也是loss太多!在本文中,我采用散文的写作方法谈谈自己对这篇paper的理解 ...
- jQuery.merge( first, second )返回: Array
jQuery.merge( first, second )返回: Array描述: 合并两个数组内容到第一个数组.first类型: Array第一个用于合并的数组,其中将会包含合并后的第二个数组的内容 ...
- 错误Fatal error: Call to undefined function mb_strlen()的解决办法
其实这个就是没有开启php_mbstring模块.Windows下只需要修改安装目录下的php.ini文件把extension=php_mbstring.dll前面的“#”号注释符去掉保存后重启Apa ...
- Java NIO 核心组件学习笔记
背景知识 同步.异步.阻塞.非阻塞 首先,这几个概念非常容易搞混淆,但NIO中又有涉及,所以总结一下[1]. 同步:API调用返回时调用者就知道操作的结果如何了(实际读取/写入了多少字节). 异步:相 ...
- 关于DOM中的model(将元素转成对象进行操作)
DOM document (html, xml) object 将文档中的HTML元素转成js的对象 通过ID找到文档的元素转成js对象 var obj = document.getElementBy ...
- Spring 加载静态资源
<mvc:default-servlet-handler/> JSP 中通过标签加载js文件或者link标签加载css文件等静态资源时要在springmvc的xml文件中配置以上设置请求就 ...