DWZ table的原生分页浅谈


Posted in Javascript onMarch 01, 2013

最近在项目开发当中很少会用到DWZ原生的table分页,往往是使用jqgrid or grid这种第三方数据绑定的表格插件,如今在项目中要求了,就必须要使用DWZ自带的table了

接下来看一段代码,我会给大家详细介绍DWZ中table分页的使用方式,以下是在MVC中实现的方式。

?<div class="pagination" targetType="navTab" totalCount="@ViewBag.totalCount" numPerPage="@ViewBag.numPerPage" pageNumShown="@ViewBag.pageNumShown" <BR>currentPage="@ViewBag.currentPage"></div>
 属性介绍

targetType:绑定方式,DWZ这里提供了"navTab" and "dialog"这两种方式,顾名思义就是分页是在标签页上还是弹出层上

totalCount:数据总行数

numPerPage:当前页数据行数

pageNumShown:总页数

currentPage:当前页码

@using (Html.BeginForm("BidPrjList", "TbUnify", null, FormMethod.Post, new { id = "pagerForm" }))
{
    <input type="hidden" name="pageNum" value="1" />
    <input type="hidden" name="numPerPage" value="@ViewBag.numPerPage" />
}

注意DWZ下分页的表单必须加上id="pagerForm"属性,否则不会执行。DWZ中表格的分页实质是将分页的方式以表单提交的形式传递至后台,由后台接收参数,获取分页信息:例如:
Request.Form["numPerPage"]

获取分页信息表单的值就是你在View中pagerForm表单下定义隐藏文本域的name,在后台接收后去请求数据源中分页后的数据,再返回至前台。

而这里存在一个小问题:首次进入此页面时,是无法触发当前分页的的表单提交事件的,所以在上面我定义了ViewBag.numPerPage动态赋值,每页分取多少条数据,前台界面只是将分页样式定义,实质数据没有绑定,所以必须要将前台传递过来的分页信息作为后台数据分页的依据,这样前台的分页才能与数据对接一致,不会造成错乱,这点要注意。

在实际项目的开发当中,我们总会把表格与过滤条件放在一起,DWZ中表格传入限制条件的方式也很简单,如上在分页表单上加入需要传入的隐藏文本域例如:

<input type="hidden" name = "Common_TbUnify_BidPrjList_HtxtPrjName" />

这样在后台就能够接受到传入的过滤条件了。

DWZ 的table分页实质是将当前标签页的数据reload,致使标签页刷新,若限制条件与分页共同使用时,这样就会存在一个问题,页面reload后会使你 的过滤条件丢失,而这里我解决的办法还是在分页的表单中加入隐藏文本域,每次把过滤条件赋值,在后台判断是否为空,是否加入过滤条件,希望大家能够注意这 点。

最后再说一点,在上面介绍了targetType,表示当前分页的方式与分页实质是标 签页的刷新,所以如果我们把包含table的View层作为部分页用异步去进行加载时,就会发现,DWZ的分页控件是不会显示的,也就无法分页,在上面已 经告诉大家每次分页是要指定type的,如果使用$.load或者@Html.Partial都是只能加载出第一页的数据,这也是DWZ中存在缺陷的地方吧,毕竟DWZ的兴起也是近年,还是存在很多问题与BUG的,尤其是他的table分页与数据绑定真心不好用,但是总体来说,DWZ其他组件与样式还是很不错的。

好了关于DWZ table分页今天就介绍到这里。

Javascript 相关文章推荐
关于window.pageYOffset和document.documentElement.scrollTop
Apr 05 Javascript
JS批量操作CSS属性详细解析
Dec 16 Javascript
Javascript中的几种URL编码方法比较
Jan 23 Javascript
jquery让指定的元素闪烁显示的方法
Mar 17 Javascript
详解JavaScript的AngularJS框架中的作用域与数据绑定
Mar 04 Javascript
jQuery+CSS3实现四种应用广泛的导航条制作实例详解
Sep 17 Javascript
jquery ui sortable拖拽后保存位置
Apr 27 jQuery
vue 2.0项目中如何引入element-ui详解
Sep 06 Javascript
JS实现合并json对象的方法
Oct 10 Javascript
element ui table(表格)实现点击一行展开功能
Dec 04 Javascript
js实现移动端轮播图
Dec 21 Javascript
JS前端基于canvas给图片添加水印
Nov 11 Javascript
jQuery编辑器KindEditor4.1.4代码高亮显示设置教程
Mar 01 #Javascript
循环 vs 递归浅谈
Feb 28 #Javascript
JavaScript对象创建及继承原理实例解剖
Feb 28 #Javascript
jquery显示和隐藏div特效实例
Feb 27 #Javascript
JS等比例缩小图片尺寸的实例
Feb 27 #Javascript
JQuery切换显示的效果实例代码
Feb 27 #Javascript
innerText和textContent对比及使用介绍
Feb 27 #Javascript
You might like
php cc攻击代码与防范方法
2012/10/18 PHP
php实现查看邮件是否已被阅读的方法
2013/12/03 PHP
php绘制一条弧线的方法
2015/01/24 PHP
php 变量引用与变量销毁机制详细介绍
2016/12/05 PHP
thinkPHP5.0框架安装教程
2017/03/25 PHP
PHP实现类似题库抽题效果
2018/08/16 PHP
PHP-FPM和Nginx的通信机制详解
2019/02/01 PHP
Laravel 使用查询构造器配合原生sql语句查询的例子
2019/10/12 PHP
jQuery移除tr无效的解决方法(tr是动态添加)
2014/09/22 Javascript
JS实现为表格动态添加标题的方法
2015/03/31 Javascript
js实现div拖动动画运行轨迹效果代码分享
2015/08/27 Javascript
JavaScript中获取HTML元素值的三种方法
2016/06/20 Javascript
javascript类型系统——undefined和null全面了解
2016/07/13 Javascript
新入门node.js必须要知道的概念(必看篇)
2016/08/10 Javascript
JavaScript中常用的验证reg
2016/10/13 Javascript
基于js实现二级下拉联动
2016/12/17 Javascript
JavaScript基本类型值-Undefined、Null、Boolean
2017/02/23 Javascript
利用Console来Debug的10个高级技巧汇总
2018/03/26 Javascript
微信小程序wepy框架笔记小结
2018/08/08 Javascript
Node.js console控制台简单用法分析
2019/01/04 Javascript
其实你可以少写点if else与switch(推荐)
2019/01/10 Javascript
vue 解除鼠标的监听事件的方法
2019/11/13 Javascript
浅谈React中组件逻辑复用的那些事儿
2020/05/21 Javascript
[01:17:47]TNC vs VGJ.S 2018国际邀请赛小组赛BO2 第一场 8.18
2018/08/19 DOTA
Python第三方Window模块文件的几种安装方法
2018/11/22 Python
解决Pytorch 训练与测试时爆显存(out of memory)的问题
2019/08/20 Python
pyqt5 QScrollArea设置在自定义侧(任何位置)
2019/09/25 Python
scrapy与selenium结合爬取数据(爬取动态网站)的示例代码
2020/09/28 Python
使用 css3 transform 属性来变换背景图的方法
2019/05/07 HTML / CSS
Sony C++笔试题
2013/03/10 面试题
武汉英思工程科技有限公司&ndash;ORACLE面试测试题目
2012/04/30 面试题
迟到检讨书300字
2014/02/14 职场文书
银行柜员与客户起冲突检讨书
2014/09/27 职场文书
民事二审代理词
2015/05/25 职场文书
教师节简报
2015/07/20 职场文书
幼儿教师三分钟演讲稿
2019/06/21 职场文书