晚上,就是刚刚,在后端管理系统中使用DWZ框架。
 先是,直接使用官网网站的Demo,dwz-jui,与编程语言无关的纯静态的那个原始项目。

很快就搭建好了左侧菜单,打开菜单后,出现Tab页面,然后显示目标页面的内容。

然后,就去关注表格分页部分。

DWZ自带的分页组件,感觉太麻烦了,一方面分页分成了4个部分显示,主要包括:
pagerForm,查询条件
pagerHeader,分页表格的头部
pagerContent,分页表格的正文
panleBar,分页条数栏目。

另一方面,分页html和JS中,需要显示后端的变量。
表格正文的list集合和分页参数都需要从后端,比如Java上下文变量中获取。见下面的例子: 

<form id="pagerForm" method="post" action="demo_page1.html">
<input type="hidden" name="status" value="${param.status}">
<input type="hidden" name="keywords" value="${param.keywords}" />
<input type="hidden" name="pageNum" value="1" />
<input type="hidden" name="numPerPage" value="${model.numPerPage}" />
<input type="hidden" name="orderField" value="${param.orderField}" />
</form> <div class="pageHeader">
<form onsubmit="return navTabSearch(this);" action="demo_page1.html" method="post">
<div class="searchBar">
<table class="searchContent">
<tr>
<td>
我的客户:<input type="text" name="keyword" />
</td>
<td>
<select class="combox" name="province">
<option value="">所有省市</option>
</select>
</td>
<td>
建档日期:<input type="text" class="date" readonly="true" />
</td>
</tr>
</table>
<div class="subBar">
<ul>
<li><div class="buttonActive"><div class="buttonContent"><button type="submit">检索</button></div></div></li>
</ul>
</div>
</div>
</form>
</div>
<div class="pageContent">
<div class="panelBar">
<ul class="toolBar">
<li><a class="add" href="demo_page4.html" target="navTab"><span>添加</span></a></li>
</ul>
</div>
<table class="table" width="100%" layoutH="138">
<thead>
<tr>
<th width="120">客户名称</th>
</tr>
</thead>
<tbody>
<tr target="sid_user" rel="1">
<td>天津农信社</td>
</tr> </tbody>
</table>
<div class="panelBar">
<div class="pages">
<span>显示</span>
<select class="combox" name="numPerPage" onchange="navTabPageBreak({numPerPage:this.value})">
<option value="20">20</option>
</select>
<span>条,共${totalCount}条</span>
</div>
<div class="pagination" targetType="navTab" totalCount="200" numPerPage="20" pageNumShown="10" currentPage="1"></div>
</div>
</div>

因此,我不太想使用这个自带的分页。
     以前,秒针某个同事写了分页组件,我改造了下,想今后自己维护一个版本。于是,在后端使用的是自己的分页组件fugrid.js。
但是,遇到了一个问题。 要么是,自己的grid组件报错,要么是dwz的dwz.ui.js的initUI函数报错。
分析问题:
 单独在新页面中,访问grid组件所在的页面,可以正常显示,说明代码是没有问题的。
 使用自带的table,initUI函数也没有报错。

继续分析:
  发现initUI方法会调用一些方法,$("div.panel", $p).jPanel();然后提示某某没有jPanel方法,最终导致grid组件卡死了。grid组件的代码,我不想修改,dwz组件的代码,还没有看懂,也不想修改,修改了今后升级就麻烦一些。
   我尝试了一种办法,既然是由于dwz报错导致grid组件一直卡死,如果捕获这个错误了?

       
  try{
initUI();
}catch(e){
console.warn(e);
}

加上try-catch块,还是报错。难道是缓存?
<script src="static/framework/dwzjs/dwz.ui.js?a=1" type="text/javascript"></script>
加上一个a参数,防止缓存,发现还是报错。

换种方式:

function initUI(_box){
var $p = $(_box || document);
try {
$("div.panel", $p).jPanel();
}catch(e){
console.warn(e);
}
}


在initUI方法内部,捕获这个异常,终于OK啦。

不需要修改dwz的业务逻辑,不需要改动grid组件的代码。
如果dwz升级了,只需要升级之后,再增加捕获异常的代码就行了,不用去关心dwz组件的逻辑。

最新文章

  1. mysql启动失败:不能创建pid文件
  2. Leetcode: Android Unlock Patterns
  3. Yii2框架打包成Phar包报错的经历
  4. kali Linux系列教程之BeFF安装与集成Metasploit
  5. 【二】php常用方法
  6. Ch04-文字列表的设计
  7. 关于封装unity3d的dll时候的进一步总结
  8. The ToolStripMenuItem visible value always false
  9. 单点登录CAS使用记(三):实现自定义验证用户登录
  10. 百度Echarts导入
  11. ADC采样工作原理详解
  12. Go学习之初出茅庐
  13. 嵌入式-迅为iTOP-4418/6818开发板编译Android镜像技术分享
  14. zabbix监控Windows-server
  15. 【转载】COM 组件设计与应用(十一)—— IDispatch 及双接口的调用
  16. call()与apply()用法
  17. LayIM.AspNetCore Middleware 开发日记(六)嵌入资源的使用,layim.config的封装
  18. 贝叶斯公式由浅入深大讲解—AI基础算法入门【转】
  19. about route
  20. 解决phantomjs输出中文乱码

热门文章

  1. 方正飞越 A600硬改BIOS激活win7的工具与方法。
  2. Java中接口继承泛型接口
  3. Javascript和jquery事件--滚动条事件和自定义滚动条事件样式
  4. SimpleDateFormat的使用问题
  5. OC学习篇之---第一个程序HelloWorld
  6. AE地图查询
  7. Codeforces Round #Pi (Div. 2) B Berland National Library
  8. 安装spark1.3.1单机环境 分类: B8_SPARK 2015-04-27 14:52 1873人阅读 评论(0) 收藏
  9. 【rlz01】完全数
  10. JSP中多条件判断