【SSH项目实战】国税协同平台-27.分页对象应用抽取pageNavigator

本文主要是介绍【SSH项目实战】国税协同平台-27.分页对象应用抽取pageNavigator,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

按照我们给信息发布管理模块编写分页功能的方式去编写,需要大费周章,我们不如把分页功能封装起来,这样这些模块包括以后扩充的模块都能使用分页的功能了。

我们回顾一下我们的InfoAction,关于分页的属性有:
[java]  view plain copy
  1. //分页对象  
  2. protected PageResult pageResult;  
  3. //页号  
  4. private int pageNo;  
  5. //页大小  
  6. private int pageSize;c  

我们没有必要以后的每一个Action都写这三个属性,我们的Action都继承了BaseAction,所以我们把这三个属性放到BaseAction中:
[java]  view plain copy
  1. package cn.edu.hpu.tax.core.action;  
  2.   
  3. import cn.edu.hpu.tax.core.page.PageResult;  
  4.   
  5. import com.opensymphony.xwork2.ActionSupport;  
  6.   
  7. public abstract class BaseAction extends ActionSupport{  
  8.     protected String[] selectedRow;   
  9.     //分页对象  
  10.     protected PageResult pageResult;  
  11.     //页号  
  12.     private int pageNo;  
  13.     //页大小  
  14.     private int pageSize;  
  15.     //默认每页页大小  
  16.     public static int DEFAULT_PAGE_SIZE=4;  
  17.       
  18.     public String[] getSelectedRow() {  
  19.         return selectedRow;  
  20.     }  
  21.     public void setSelectedRow(String[] selectedRow) {  
  22.         this.selectedRow = selectedRow;  
  23.     }  
  24.     public PageResult getPageResult() {  
  25.         return pageResult;  
  26.     }  
  27.     public void setPageResult(PageResult pageResult) {  
  28.         this.pageResult = pageResult;  
  29.     }  
  30.     public int getPageNo() {  
  31.         return pageNo;  
  32.     }  
  33.     public void setPageNo(int pageNo) {  
  34.         this.pageNo = pageNo;  
  35.     }  
  36.     public int getPageSize() {  
  37.         //给的默认的分页大小  
  38.         if(pageSize < 1) pageSize = DEFAULT_PAGE_SIZE;  
  39.         return pageSize;  
  40.     }  
  41.     public void setPageSize(int pageSize) {  
  42.         this.pageSize = pageSize;  
  43.     }  
  44. }  

然后Action之前的infoList我们也不需要了(删除这个属性以及get和set方法),因为我们现在只从pageResult中拿数据。

然后我们修改UserAction的Action,将userList删除(删除这个属性以及get和set方法)(删除原因和上面的原因一样),然后改造listUI方法:
[java]  view plain copy
  1. //列表页面  
  2. public String listUI() throws Exception{  
  3.     try {  
  4.         QueryHelper queryHelper=new QueryHelper(User.class,"u");  
  5.         if(user != null){  
  6.             if(StringUtils.isNotBlank(user.getName())){  
  7.                 user.setName(URLDecoder.decode(user.getName(),"utf-8"));  
  8.                 queryHelper.addCondition("u.name like ?""%"+user.getName()+"%");  
  9.             }  
  10.         }  
  11.         pageResult=userService.getPageResult(queryHelper,getPageNo(),getPageSize());  
  12.     } catch (Exception e) {  
  13.         throw new Exception(e.getMessage());  
  14.     }  
  15.     return "listUI";  
  16. }  
还需要加一个strName来防止用户名查询条件被覆盖:
[java]  view plain copy
  1. private String strName;  
  2.   
  3. public String getStrName() {  
  4.     return strName;  
  5. }  
  6. public void setStrName(String strName) {  
  7.     this.strName = strName;  
  8. }  

需要使用strName来防止用户名查询条件被覆盖的方法有增、删、修方法,可以去对应的方法去修改,这里不再赘述代码。
然后别忘记在user-struts.xml加上list跳转时的参数strName的配置:
[html]  view plain copy
  1. <result name="list" type="redirectAction">  
  2.     <param name="actionName">user_listUI</param>  
  3.     <param name="user.name">${strName}</param>  
  4.     <param name="encode">true</param><!-- 需要编码 -->  
  5. </result>  

然后类中的其他引用userList的报错的地方可以不去用这个对象,直接使用userService.findObjects()来代替。

最后,别忘记把我们user的list.jsp中的数据迭代中的value="userList"改为value="pageResult.items":
[html]  view plain copy
  1. <s:iterator value="pageResult.items" status="st">  
  2.     <!--中间代码不再赘述-->  
  3. </s:iterator>  

接下来roleAction的改造和上面一样,我就不再赘述了,roleAction的listUI改造以后变为:
[java]  view plain copy
  1. //列表页面  
  2. public String listUI() throws Exception{  
  3.     try {  
  4.         //加载权限集合  
  5.         ActionContext.getContext().getContextMap().put("privilegeMap", Constant.PRIVILEGE_MAP);  
  6.         QueryHelper queryHelper=new QueryHelper(Role.class,"r");  
  7.         if(role != null){  
  8.             if(StringUtils.isNotBlank(role.getName())){  
  9.                 role.setName(URLDecoder.decode(role.getName(),"utf-8"));  
  10.                 queryHelper.addCondition("r.name like ?""%"+role.getName()+"%");  
  11.             }  
  12.         }  
  13.         pageResult=roleService.getPageResult(queryHelper,getPageNo(),getPageSize());  
  14.     } catch (Exception e) {  
  15.         throw new Exception(e.getMessage());  
  16.     }  
  17.     return "listUI";  
  18. }  

当然strName也是要加和修改增、删、修方法的。role-struts.xml中list跳转时的参数strName也要配置的。
最后,别忘记把我们role的list.jsp中的数据迭代中的value="roleList"改为value="pageResult.items":

Action全部改造完毕之后,我们要对前端jsp中的分页部分进行抽取:

我们之前的jsp页面分页部分有以下:
[html]  view plain copy
  1. <div class="c_pate" style="margin-top: 5px;">  
  2.         <!-- 如果页数为空不显示分页选项 -->  
  3.         <s:if test="pageResult.totalCount > 0">  
  4.         <table width="100%" class="pageDown" border="0" cellspacing="0"  
  5.             cellpadding="0">  
  6.             <tr>  
  7.                 <td align="right">  
  8.                     总共<s:property value="pageResult.totalCount"/>条记录,当前第 <s:property value="pageResult.pageNo"/> 页,  
  9.                     共 <s:property value="pageResult.totalPageCount"/> 页   
  10.                     <!-- 非第一页才有“上一页”选项 -->  
  11.                     <s:if test="pageResult.pageNo>1">  
  12.                           <a href="javascript:doGoPage(<s:property value='pageResult.pageNo-1'/>)">上一页</a>  
  13.                     </s:if>  
  14.                     <!-- 非最后一页才有“下一页”选项 -->  
  15.                     <s:if test="pageResult.pageNo < pageResult.totalPageCount">  
  16.                           <a href="javascript:doGoPage(<s:property value='pageResult.pageNo+1'/>)">下一页</a>  
  17.                     </s:if>  
  18.                     到 <input id="pageNo" name="pageNo" type="text" style="width: 30px;" onkeypress="if(event.keyCode == 13){doGoPage(this.value);}" min="1"  
  19.                     max="" value="<s:property value="pageResult.pageNo"/>/>     
  20.                 </td>  
  21.             </tr>  
  22.         </table>  
  23.         </s:if><s:else>暂无数据!</s:else>   
  24.         </div>  
  25.         <script type="text/javascript">  
  26.         //翻页方法  
  27.         function doGoPage(pageNo){  
  28.             document.getElementById("pageNo").value = pageNo;  
  29.             document.forms[0].action="${basePath}tax/info_listUI.action";  
  30.             document.forms[0].submit();  
  31.         }  
  32.         </script>  
  33.         </div>  

我们不需要每一页都去写这些代码,我们可以把上面的代码单独封装到一个jsp文件中,然后每个需要写分页功能的jsp页面都可以去引用它。我们把上面代码封装至/common/pageNavigator.jsp中:
[html]  view plain copy
  1. <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>  
  2. <%@ taglib prefix="s" uri="/struts-tags"%>  
  3. <div class="c_pate" style="margin-top: 5px;">  
  4.         <!-- 如果页数为空不显示分页选项 -->  
  5.         <s:if test="pageResult.totalCount > 0">  
  6.         <table width="100%" class="pageDown" border="0" cellspacing="0"  
  7.             cellpadding="0">  
  8.             <tr>  
  9.                 <td align="right">  
  10.                     总共<s:property value="pageResult.totalCount"/>条记录,当前第 <s:property value="pageResult.pageNo"/> 页,  
  11.                     共 <s:property value="pageResult.totalPageCount"/> 页   
  12.                     <!-- 非第一页才有“上一页”选项 -->  
  13.                     <s:if test="pageResult.pageNo>1">  
  14.                           <a href="javascript:doGoPage(<s:property value='pageResult.pageNo-1'/>)">上一页</a>  
  15.                     </s:if>  
  16.                     <!-- 非最后一页才有“下一页”选项 -->  
  17.                     <s:if test="pageResult.pageNo < pageResult.totalPageCount">  
  18.                           <a href="javascript:doGoPage(<s:property value='pageResult.pageNo+1'/>)">下一页</a>  
  19.                     </s:if>  
  20.                     到 <input id="pageNo" name="pageNo" type="text" style="width: 30px;" onkeypress="if(event.keyCode == 13){doGoPage(this.value);}" min="1"  
  21.                     max="" value="<s:property value="pageResult.pageNo"/>/>     
  22.                 </td>  
  23.             </tr>  
  24.         </table>  
  25.         </s:if><s:else>暂无数据!</s:else>   
  26. </div>  
  27. <script type="text/javascript">  
  28. //翻页方法  
  29. function doGoPage(pageNo){  
  30.     document.getElementById("pageNo").value = pageNo;  
  31.     document.forms[0].action=list_url;  
  32.     document.forms[0].submit();  
  33. }  
  34. </script>  

我们把跳转的路径封装在了listUI.jsp的list_url变量中:
var list_url="${basePath}tax/XXX_listUI.action";(xxx是info、user或者role)

顺便把没有搜索功能的添加搜索功能
(<input type="button" class="s_button" value="搜 索" οnclick="doSearch()"/>)
[javascript]  view plain copy
  1. function doSearch(){  
  2.     //重置页号  
  3.     $("#pageNo").val(1);  
  4.     document.forms[0].action = list_url;  
  5.     document.forms[0].submit();  
  6. }  

然后我们在listUI.jsp中放置分页代码的位置添加动态包含代码:
[html]  view plain copy
  1. <jsp:include page="/common/pageNavigator.jsp"></jsp:include>  

这样我们每一个想使用分页功能的模块都可以直接引入这个代码(我们在user、role的listUI.jsp代码中也这么改造)。

这样,我们的“用户管理”、“角色管理”和“信息发布管理”这三个模块都拥有了“搜索”和“分页”功能了。

这篇关于【SSH项目实战】国税协同平台-27.分页对象应用抽取pageNavigator的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/334560

相关文章

SpringShell命令行之交互式Shell应用开发方式

《SpringShell命令行之交互式Shell应用开发方式》本文将深入探讨SpringShell的核心特性、实现方式及应用场景,帮助开发者掌握这一强大工具,具有很好的参考价值,希望对大家有所帮助,如... 目录引言一、Spring Shell概述二、创建命令类三、命令参数处理四、命令分组与帮助系统五、自定

SpringBoot应用中出现的Full GC问题的场景与解决

《SpringBoot应用中出现的FullGC问题的场景与解决》这篇文章主要为大家详细介绍了SpringBoot应用中出现的FullGC问题的场景与解决方法,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录Full GC的原理与触发条件原理触发条件对Spring Boot应用的影响示例代码优化建议结论F

深入理解Apache Kafka(分布式流处理平台)

《深入理解ApacheKafka(分布式流处理平台)》ApacheKafka作为现代分布式系统中的核心中间件,为构建高吞吐量、低延迟的数据管道提供了强大支持,本文将深入探讨Kafka的核心概念、架构... 目录引言一、Apache Kafka概述1.1 什么是Kafka?1.2 Kafka的核心概念二、Ka

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

MySQL 分区与分库分表策略应用小结

《MySQL分区与分库分表策略应用小结》在大数据量、复杂查询和高并发的应用场景下,单一数据库往往难以满足性能和扩展性的要求,本文将详细介绍这两种策略的基本概念、实现方法及优缺点,并通过实际案例展示如... 目录mysql 分区与分库分表策略1. 数据库水平拆分的背景2. MySQL 分区策略2.1 分区概念

Spring Shell 命令行实现交互式Shell应用开发

《SpringShell命令行实现交互式Shell应用开发》本文主要介绍了SpringShell命令行实现交互式Shell应用开发,能够帮助开发者快速构建功能丰富的命令行应用程序,具有一定的参考价... 目录引言一、Spring Shell概述二、创建命令类三、命令参数处理四、命令分组与帮助系统五、自定义S

Spring Boot项目部署命令java -jar的各种参数及作用详解

《SpringBoot项目部署命令java-jar的各种参数及作用详解》:本文主要介绍SpringBoot项目部署命令java-jar的各种参数及作用的相关资料,包括设置内存大小、垃圾回收... 目录前言一、基础命令结构二、常见的 Java 命令参数1. 设置内存大小2. 配置垃圾回收器3. 配置线程栈大小

在Android平台上实现消息推送功能

《在Android平台上实现消息推送功能》随着移动互联网应用的飞速发展,消息推送已成为移动应用中不可或缺的功能,在Android平台上,实现消息推送涉及到服务端的消息发送、客户端的消息接收、通知渠道(... 目录一、项目概述二、相关知识介绍2.1 消息推送的基本原理2.2 Firebase Cloud Me

Spring Boot项目中结合MyBatis实现MySQL的自动主从切换功能

《SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能》:本文主要介绍SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能,本文分步骤给大家介绍的... 目录原理解析1. mysql主从复制(Master-Slave Replication)2. 读写分离3.

C语言函数递归实际应用举例详解

《C语言函数递归实际应用举例详解》程序调用自身的编程技巧称为递归,递归做为一种算法在程序设计语言中广泛应用,:本文主要介绍C语言函数递归实际应用举例的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录前言一、递归的概念与思想二、递归的限制条件 三、递归的实际应用举例(一)求 n 的阶乘(二)顺序打印