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 相关文章推荐
javascript一点特殊用法
May 28 Javascript
JavaScript 定义function的三种方式小结
Oct 16 Javascript
js定时调用方法成功后并停止调用示例
Apr 08 Javascript
javascript打开word文档的方法
Apr 16 Javascript
struts2+jquery组合验证注册用户是否存在
Apr 30 Javascript
浅析javascript 定时器
Dec 23 Javascript
jquery插件之文字间歇自动向上滚动效果代码
Feb 25 Javascript
基于require.js的使用(实例讲解)
Sep 07 Javascript
bing Map 在vue项目中的使用详解
Apr 09 Javascript
vue中v-text / v-html使用实例代码详解
Apr 02 Javascript
JS实现滚动条触底加载更多
Sep 19 Javascript
如何实现vue的tree组件
Dec 03 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
基于preg_match_all采集后数据处理的一点心得笔记(编码转换和正则匹配)
2014/01/31 PHP
php 使用 __call实现重载功能示例
2019/11/18 PHP
ThinkPHP5.1验证码功能实现的示例代码
2020/06/08 PHP
脚本收藏iframe
2006/07/21 Javascript
ASP.NET jQuery 实例13 原创jQuery文本框字符限制插件-TextArea Counter
2012/02/03 Javascript
artDialog 4.1.5 Dreamweaver代码提示/补全插件 附下载
2012/07/31 Javascript
浅析jQuery(function(){})与(function(){})(jQuery)之间的区别
2014/01/09 Javascript
JavaScript使用ActiveXObject访问Access和SQL Server数据库
2015/04/02 Javascript
jquery中表单 多选框的一种巧妙写法
2015/09/06 Javascript
浅析jQuery Ajax通用js封装
2016/06/22 Javascript
AngularJS基础 ng-hide 指令用法及示例代码
2016/08/01 Javascript
js H5 canvas投篮小游戏
2016/08/18 Javascript
jquery-mobile表单的创建方法详解
2016/11/23 Javascript
AngularJS基于provider实现全局变量的读取和赋值方法
2017/06/28 Javascript
jsonp跨域请求详解
2017/07/13 Javascript
浅析vue-router中params和query的区别
2019/12/24 Javascript
vue页面更新patch的实现示例
2020/03/25 Javascript
python正则表达式re模块详细介绍
2014/05/29 Python
Python with用法实例
2015/04/14 Python
python生成随机图形验证码详解
2017/11/08 Python
python并发编程之线程实例解析
2017/12/27 Python
Python logging模块用法示例
2018/08/28 Python
使用django-guardian实现django-admin的行级权限控制的方法
2018/10/30 Python
python爬虫 2019中国好声音评论爬取过程解析
2019/08/26 Python
python + selenium 刷B站播放量的实例代码
2020/06/12 Python
Lookfantastic希腊官网:英国知名美妆购物网站
2018/09/15 全球购物
亚马逊意大利站点:Amazon.it
2020/12/31 全球购物
C语言笔试集
2012/07/24 面试题
医院辞职信范文
2014/01/17 职场文书
电子工程专业毕业生求职信
2014/03/14 职场文书
党员岗位承诺口号大全
2014/03/28 职场文书
《彩色世界》教学反思
2014/04/12 职场文书
胡雪岩故居导游词
2015/02/06 职场文书
欠条格式范本
2015/07/03 职场文书
Python机器学习之决策树和随机森林
2021/07/15 Javascript
Python+Selenium实现读取网易邮箱验证码
2022/03/13 Python