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 相关文章推荐
jQuery 性能优化指南(3)
May 21 Javascript
ASP小贴士/ASP Tips javascript tips可以当桌面
Dec 10 Javascript
JavaScript ( (__ = !$ + $)[+$] + ({} + $)[_/_] +({} + $)[_/_] )
Feb 25 Javascript
node.js中的fs.rename方法使用说明
Dec 16 Javascript
jquery隔行换色效果实现方法
Jan 15 Javascript
如何动态加载外部Javascript文件
Dec 02 Javascript
jQuery实现简单的图片查看器
Sep 11 Javascript
Bootstrap3 内联单选和多选框
Dec 29 Javascript
vue.js实例todoList项目
Jul 07 Javascript
vue项目启动出现cannot GET /服务错误的解决方法
Apr 26 Javascript
jQuery使用jsonp实现百度搜索的示例代码
Jul 08 jQuery
Vue详细的入门笔记
May 10 Vue.js
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实现数字补零功能的2个函数介绍
2014/05/12 PHP
初识Laravel
2014/10/30 PHP
php自动更新版权信息显示的方法
2015/06/19 PHP
PHP命名空间和自动加载类
2016/04/03 PHP
PHP实现生成推广海报的方法详解
2018/03/14 PHP
基于swoole实现多人聊天室
2018/06/14 PHP
学习YUI.Ext基础第一天
2007/03/10 Javascript
js中AppendChild与insertBefore的用法详细解析
2013/12/16 Javascript
JavaScript按位运算符的应用简析
2014/02/04 Javascript
jQuery的css()方法用法实例
2014/12/24 Javascript
JavaScript中的cacheStorage使用详解
2015/07/29 Javascript
jQuery使用contains过滤器实现精确匹配方法详解
2016/02/25 Javascript
浏览器调试动态js脚本的方法(图解)
2018/01/19 Javascript
Node 升级到最新稳定版的方法分享
2018/05/17 Javascript
Vue监听页面刷新和关闭功能
2019/06/20 Javascript
解决layui 三级联动下拉框更新时回显的问题
2019/09/03 Javascript
三步实现ionic3点击退出app程序
2019/09/17 Javascript
[52:08]DOTA2上海特级锦标赛主赛事日 - 3 败者组第三轮#2Fnatic VS OG第一局
2016/03/05 DOTA
[00:35]可解锁地面特效
2018/12/20 DOTA
python实现判断数组是否包含指定元素的方法
2015/07/15 Python
Python实现的递归神经网络简单示例
2017/08/11 Python
Python中矩阵库Numpy基本操作详解
2017/11/21 Python
python xlsxwriter库生成图表的应用示例
2018/03/16 Python
python3 kmp 字符串匹配的方法
2018/07/07 Python
基于 Django 的手机管理系统实现过程详解
2019/08/16 Python
关于HTML5的22个初级技巧(图文教程)
2012/06/21 HTML / CSS
理肤泉英国官网:La Roche-Posay英国
2019/01/14 全球购物
美国在线购买和出售礼品卡网站:EJ Gift Cards
2019/06/09 全球购物
茶叶店创业计划书范文
2014/01/19 职场文书
医药营销个人求职信范文
2014/02/07 职场文书
yy司仪主持词
2014/03/22 职场文书
今冬明春火灾防控工作方案
2014/05/29 职场文书
节能环保标语
2014/06/12 职场文书
踏青活动策划方案
2014/08/19 职场文书
反四风对照检查材料
2014/09/22 职场文书
《雀魂PONG☆》4月1日播出 PV角色设定情报
2022/03/20 日漫