drp扫尾工作总结

2024-02-15 23:18
文章标签 总结 工作 drp 扫尾

本文主要是介绍drp扫尾工作总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这几天对DRP项目进行扫尾工作,完善了其中一个功能:JfreeChart显示分销商分布情况。原来没有根据区域和省进行动态显示,这几天完善了这个功能。在这其中遇到一些困难,说起来都是小问题,可是就是这些“小问题”搞的人很疲惫,却又越挫越勇。

第一个问题:递归:

由于区域、省、分销商都在一张表中管理,他们的关系是:

所以,要取得每个区域(或省)下的全部分销商,就需要用到递归。递归在学习VB的时候就用过了,个人感觉很简单,不过,这里还是犯了一个错,就是递归的执行过程不了解,也就是不了解递归的本质,造成运行时候出现很多难以描述的异常。经过N久的战斗,把原来所有的代码写在一个方法内拆分成三个方法,这样达到了解耦的目的,也符合了单一职责原则。对于递归就不多说了。

第二,在下拉列表联动的实现中,原来采用的是Dom4J读写XML文件实现的,这次我想着用其他的方式实现,比如Servlet返回的类型为List,到Jsp页面进行简单的渲染,不过这里看似简单,实际很麻烦:如果用Javascript来跳转页面,就会刷新页面,另外,第一个下拉列表的内容由于刷新了,不能定位到跳转之前的值,而且下拉列表中的内容也会消失,当然,这些都是可以解决的,不过不太熟练,就会花很长时间,而且也不是想要的效果。若是用Ajax,问题就来了,不会对于返回的List进行循环遍历取值。这看着很简单吧,应该网上一搜一大堆的,结果却出人意料,大部分的结果显示:使用JSON、DWR。搞了一天找到我想要的答案。于是我猜我想要的答案是不是不存在哩?下面把问题贴到这里,希望有高人路过帮我解答:

问题是:下拉列表联动:一个下拉列表,当它改变的时候,另外一个下拉菜单也跟着改变。不过改变的值是访问servlet返回的。现在servlet返回了一个List,我要把这个List的值取出来放到第二个下拉菜单中。

我的Servlet代码是这样的:

List<Client> provList= ClientManager.getInstance().selectProvByRegionId(regionId);

response.getWriter().print(provList);

//这样能把集合List(list中的是实体类对象)放到了response中么?

Jsp中的Ajax代码:

xmlHttp.open("GET", url, true);

xmlHttp.onreadystatechange = function() {

if (xmlHttp.readyState == 4) {

if (xmlHttp.status == 200) {

var list = xmlHttp.responseText;//list是servlet返回的LIst

*******; //请问我这里怎样遍历得到list的值呀?谢谢

}

}

}

xmlHttp.send(null);

 

第三、动态给iframe 的 src 赋值:

由于iframe中要显示的东西是根据条件改变的,因此iframe的src也是动态的。具体问题不说了,网上查了很多,最后只有一个解决了:

       document.frames[0].navigate(src);

 

DRP遗留问题:

每个项目都没有完美,可以继续完善,对于DRP系统,我认为该告一段落了,要继续下一步。对于这个项目学习到的用到的技术要点和思想要点如下:

思想:架构:MVC三层架构;模式:配置文件+反射+抽象工厂模式实现数据处理灵活替换;声明式服务设置字符集和异常处理;数据库:使用连接池和JNDI;版本控制:CVS(SVN)。

 

技术:

1、webservice 分布式通信

2、Dom4J读写XML + Ajax实现异步式下拉列表联动

3、JfreeChart显示数据报表

4、JSTL渲染页面

5、Ajax 异步验证数据用户代码等是否存在

6、CSS设计界面

7、SSH框架

 

遗留问题:

1、web.xml文件中的一些配置的用处,如:Listener

2、关于Ajax和Javascript的深入学习

3、部分功能还有待完善

4、每个页面第一次加载的时候太慢

5、个别细节不够人性化,如提示信息没有及时清除

6、这个问题比较大:错误处理有点问题:当遇到异常时候就会跳到登录页面,这个是在Filter中配置的,但是我把Filter注释后还是会跳转。

 

 

这篇关于drp扫尾工作总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C#实现将Excel工作表拆分为多个窗格

《C#实现将Excel工作表拆分为多个窗格》在日常工作中,我们经常需要处理包含大量数据的Excel文件,本文将深入探讨如何在C#中利用强大的Spire.XLSfor.NET自动化实现Excel工作表的... 目录为什么需要拆分 Excel 窗格借助 Spire.XLS for .NET 实现冻结窗格(Fro

C# List.Sort四种重载总结

《C#List.Sort四种重载总结》本文详细分析了C#中List.Sort()方法的四种重载形式及其实现原理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友... 目录1. Sort方法的四种重载2. 具体使用- List.Sort();- IComparable

SpringBoot项目整合Netty启动失败的常见错误总结

《SpringBoot项目整合Netty启动失败的常见错误总结》本文总结了SpringBoot集成Netty时常见的8类问题及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录一、端口冲突问题1. Tomcat与Netty端口冲突二、主线程被阻塞问题1. Netty启动阻

SpringBoot整合Kafka启动失败的常见错误问题总结(推荐)

《SpringBoot整合Kafka启动失败的常见错误问题总结(推荐)》本文总结了SpringBoot项目整合Kafka启动失败的常见错误,包括Kafka服务器连接问题、序列化配置错误、依赖配置问题、... 目录一、Kafka服务器连接问题1. Kafka服务器无法连接2. 开发环境与生产环境网络不通二、序

python3中正则表达式处理函数用法总结

《python3中正则表达式处理函数用法总结》Python中的正则表达式是一个强大的文本处理工具,用于匹配、查找、替换等操作,在Python中正则表达式的操作主要通过内置的re模块来实现,这篇文章主要... 目录前言re.match函数re.search方法re.match 与 re.search的区别检索

C#借助Spire.XLS for .NET实现Excel工作表自动化样式设置

《C#借助Spire.XLSfor.NET实现Excel工作表自动化样式设置》作为C#开发者,我们经常需要处理Excel文件,本文将深入探讨如何利用C#代码,借助强大的Spire.XLSfor.N... 目录为什么需要自动化工作表样式使用 Spire.XLS for .NET 实现工作表整体样式设置样式配置

Python版本与package版本兼容性检查方法总结

《Python版本与package版本兼容性检查方法总结》:本文主要介绍Python版本与package版本兼容性检查方法的相关资料,文中提供四种检查方法,分别是pip查询、conda管理、PyP... 目录引言为什么会出现兼容性问题方法一:用 pip 官方命令查询可用版本方法二:conda 管理包环境方法

pycharm跑python项目易出错的问题总结

《pycharm跑python项目易出错的问题总结》:本文主要介绍pycharm跑python项目易出错问题的相关资料,当你在PyCharm中运行Python程序时遇到报错,可以按照以下步骤进行排... 1. 一定不要在pycharm终端里面创建环境安装别人的项目子模块等,有可能出现的问题就是你不报错都安装

C#利用Free Spire.XLS for .NET复制Excel工作表

《C#利用FreeSpire.XLSfor.NET复制Excel工作表》在日常的.NET开发中,我们经常需要操作Excel文件,本文将详细介绍C#如何使用FreeSpire.XLSfor.NET... 目录1. 环境准备2. 核心功能3. android示例代码3.1 在同一工作簿内复制工作表3.2 在不同

Python中logging模块用法示例总结

《Python中logging模块用法示例总结》在Python中logging模块是一个强大的日志记录工具,它允许用户将程序运行期间产生的日志信息输出到控制台或者写入到文件中,:本文主要介绍Pyt... 目录前言一. 基本使用1. 五种日志等级2.  设置报告等级3. 自定义格式4. C语言风格的格式化方法