【SSH项目实战】国税协同平台-25.查询条件回显

2023-11-03 01:18

本文主要是介绍【SSH项目实战】国税协同平台-25.查询条件回显,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


解释一下回显,例如你翻到100页,这一页有一个信息需要修改,当你点击修改并修改完毕的时候,发现并没有回到之前的第100页,而是回到了第1页!!你是不是就抓狂了?而且你在输入框中的的查询条件也可能改变或消失,这就是没有做数据回显的后果。所以,我们要为我们的这个模块做数据回显功能。

我们去分类查询的依据就是info.title值,如果有,我们就按照那个排序并列出结果,如果没有我们就去取所有的,当我们点击“编辑”“删除”等操作的时候,返回的是InfoAction中的listUI方法,并没有带任何参数过去,那么listUI方法检测到没有info.title参数,那么就会列出所有的结果,到时我们的原来的查询结果丢失。

究其最原始的原因,其实是“重定向”惹的祸。因为“重定向”是转向新的一个jsp页面,后台是不带任何值过去的(包括request都是新的)。我们的info.title就是在重定向过程中丢失的。

我们现在来解决参数丢失的问题来解决“回显”功能。

我们在info的struts配置文件中的list重定向配置中添加一个参数“info.title”:
[html]  view plain copy
  1. <?xml version="1.0" encoding="UTF-8" ?>  
  2. <!DOCTYPE struts PUBLIC  
  3.     "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"  
  4.     "http://struts.apache.org/dtds/struts-2.3.dtd">  
  5.   
  6.   
  7. <struts>  
  8.     <package name="info-action" namespace="/tax" extends="base-default">  
  9.         <action name="info_*" class="cn.edu.hpu.tax.info.action.InfoAction" method="{1}">  
  10.             <result name="{1}">/WEB-INF/jsp/tax/info/{1}.jsp</result>  
  11.             <result name="list" type="redirectAction">  
  12.                 <param name="actionName">info_listUI</param>  
  13.                 <param name="info.title">${info.title}</param>            
  14.                                 <param name="encode">true</param><!-- 需要编码 -->  
  15.             </result>  
  16.         </action>  
  17.     </package>  
  18. </struts>  

然后在接收info.title的时候我们进行解码:
[java]  view plain copy
  1. info.setTitle(URLDecoder.decode(info.getTitle(),"utf-8"));  

这样我们每次在重定向的时候就会将这个参数一并传过去,我们的搜索结果又会重新回显出来。

测试:
搜索“1”:


结果:


编辑一个


点击“返回”后结果:

说明我们的回显暂时完成,但是我们还有问题:

当我们搜索“测试”的时候,出现以下结果:


然后我们点击“新增”:
添加标题是“新闻前线11”,然后点击保存:



保存之后返回的是这样的结果;


很显然这不是我们需要的,我们需要的是之前搜索“测试”的时候的结果列表,这里是因为我们新增的info.title覆盖了原来的info.title条件。

我们解决这个问题。
既然我们的info.title会因为增删改而改变,那么我们就把之前的info.title保存在一个临时变量里,不管之后info.title或者info再发任何改变,我们之前搜索使用的info.title值都不会再丢失或覆盖:
这里我们在InfoAction中把这个临时变量设为:
[java]  view plain copy
  1. private String strTitle;  
  2.   
  3. public String getStrTitle() {  
  4.     return strTitle;  
  5. }  
  6. public void setStrTitle(String strTitle) {  
  7.     this.strTitle = strTitle;  
  8. }  

然后在InfoAction中的新增页面跳转方法addUI、编辑页面跳转方法editUI、删除方法delete以及异步信息发布publicInfo方法中添加此代码(创建或更新、取得info前):
[java]  view plain copy
  1. //解决查询条件覆盖的问题  
  2. strTitle=info.getTitle();  

然后我们在“编辑”“新增”的填写数据的页面把strTitle值当做隐藏数据放置在jsp页面中,当点击“修改”和“保存”的时候会随之一传至列表界面,就可以带着原来的查询条件回显了。
[html]  view plain copy
  1. <s:hidden name="strTitle"/>  

然后修改我们的struts的配置文件,将info.title的引用值改为strTitle:
[html]  view plain copy
  1. <result name="list" type="redirectAction">  
  2.     <param name="actionName">info_listUI</param>  
  3.     <param name="info.title">${strTitle}</param>  
  4.     <param name="encode">true</param><!-- 需要编码 -->  
  5. </result>  

我们测试一下:
我们搜索“测试”:


然后点击新增,新增一个叫“新闻摘要22”的文章:

点击保存之后跳转至这个页面:



点击编辑,将"测试1"改为"测试12"

点击保存之后跳转至这个页面:


说明我们的查询条件不在随增删修而发生改变,我们的查询条件回显算是圆满完成了!

下面就是我们发生这个问题的整体原因总结:


至此我们的查询条件回显功能完成。

我们的页面也需要回显,不能因为编辑完回退到第一页而不是刚刚点编辑的那一页,究其原因是我们没有将当前页码pageNo参数传递过去,所以我们在每一个编辑页面都将pageNo作为隐式参数包含进去:
[html]  view plain copy
  1. <s:hidden name="pageNo"/>  

在进行list重定向的时候我们也把pageNo给包含进去,这里在info-struts.xml中去配置(就是下面的<param name="pageNo">${pageNo}</param>这一句):
[html]  view plain copy
  1. <result name="list" type="redirectAction">  
  2.     <param name="actionName">info_listUI</param>  
  3.     <param name="info.title">${strTitle}</param>  
  4.         <param name="pageNo">${pageNo}</param>  
  5.     <param name="encode">true</param><!-- 需要编码 -->  
  6. </result>  

这样就再也不会发生你翻到100页,修改其中某个信息的保存或回退时候,发现并没有回到之前的第100页,而是回到了第1页这种抓狂的情况。

这篇关于【SSH项目实战】国税协同平台-25.查询条件回显的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SpringBoot项目注入 traceId 追踪整个请求的日志链路(过程详解)

《SpringBoot项目注入traceId追踪整个请求的日志链路(过程详解)》本文介绍了如何在单体SpringBoot项目中通过手动实现过滤器或拦截器来注入traceId,以追踪整个请求的日志链... SpringBoot项目注入 traceId 来追踪整个请求的日志链路,有了 traceId, 我们在排

Java实战之利用POI生成Excel图表

《Java实战之利用POI生成Excel图表》ApachePOI是Java生态中处理Office文档的核心工具,这篇文章主要为大家详细介绍了如何在Excel中创建折线图,柱状图,饼图等常见图表,需要的... 目录一、环境配置与依赖管理二、数据源准备与工作表构建三、图表生成核心步骤1. 折线图(Line Ch

Java使用Tesseract-OCR实战教程

《Java使用Tesseract-OCR实战教程》本文介绍了如何在Java中使用Tesseract-OCR进行文本提取,包括Tesseract-OCR的安装、中文训练库的配置、依赖库的引入以及具体的代... 目录Java使用Tesseract-OCRTesseract-OCR安装配置中文训练库引入依赖代码实

部署Vue项目到服务器后404错误的原因及解决方案

《部署Vue项目到服务器后404错误的原因及解决方案》文章介绍了Vue项目部署步骤以及404错误的解决方案,部署步骤包括构建项目、上传文件、配置Web服务器、重启Nginx和访问域名,404错误通常是... 目录一、vue项目部署步骤二、404错误原因及解决方案错误场景原因分析解决方案一、Vue项目部署步骤

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

golang内存对齐的项目实践

《golang内存对齐的项目实践》本文主要介绍了golang内存对齐的项目实践,内存对齐不仅有助于提高内存访问效率,还确保了与硬件接口的兼容性,是Go语言编程中不可忽视的重要优化手段,下面就来介绍一下... 目录一、结构体中的字段顺序与内存对齐二、内存对齐的原理与规则三、调整结构体字段顺序优化内存对齐四、内

SQL 中多表查询的常见连接方式详解

《SQL中多表查询的常见连接方式详解》本文介绍SQL中多表查询的常见连接方式,包括内连接(INNERJOIN)、左连接(LEFTJOIN)、右连接(RIGHTJOIN)、全外连接(FULLOUTER... 目录一、连接类型图表(ASCII 形式)二、前置代码(创建示例表)三、连接方式代码示例1. 内连接(I

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

配置springboot项目动静分离打包分离lib方式

《配置springboot项目动静分离打包分离lib方式》本文介绍了如何将SpringBoot工程中的静态资源和配置文件分离出来,以减少jar包大小,方便修改配置文件,通过在jar包同级目录创建co... 目录前言1、分离配置文件原理2、pom文件配置3、使用package命令打包4、总结前言默认情况下,

在Java中使用ModelMapper简化Shapefile属性转JavaBean实战过程

《在Java中使用ModelMapper简化Shapefile属性转JavaBean实战过程》本文介绍了在Java中使用ModelMapper库简化Shapefile属性转JavaBean的过程,对比... 目录前言一、原始的处理办法1、使用Set方法来转换2、使用构造方法转换二、基于ModelMapper