浏览 5685 次
锁定老帖子 主题:struts标签,请你走开(系列一)
该帖已经被评为隐藏帖
|
|
---|---|
作者 | 正文 |
发表时间:2006-09-25
struts标签之死穴一 不支持嵌套 看看这种常见的需求吧。一个用户隶属于一个职能部门,比如 项目要求 职能部门有五个(乱写的) 1、企划部 2、网络集成部 3、行政部 4、营销部 5、产品部 项目要求 一共有二个员工 1、张三 隶属于行政部 2、李四 隶属于营销部 而你想把张三和李四都列表出来,显示为如下: 姓名 部门名称 张三 行政部 李四 营销部 而且还需要用户的列表链接到修改页面当中(假如只修改部门)应该如何做呢。 在使用struts标签是很难做到的,除非你非常不在意内存的使用(乱写技术性代码) 看看JSTL是如何做的吧。 从STRUTS的ACTION当中加载两个对象 List GetAllDept = UserDAO.GetAllDept();//取得所有部门 List GetALLUser = UserDAO.GetAllUser();//取得所有用户 request.setAttribute("View_Dept", GetAllDept); request.setAttribute("View_User", GetALLUser); /code] 在页面当中加入对JSTL的引用 <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> 然后写代码如下: <table> <tr> <td align="center"> <a href="User.do?method=EditUser&UserId=<c:out value='${View_User.UserId}'/>"> <c:out value="${View_User.UserName}" /> </a> </td> <td align="center"> <c:forEach items="${View_Dept}" var="View_Dept"> <c:if test="${View_User.Dept.DeptId==View_Dept.DeptId}"> <c:out value="${View_Dept.DeptName}" /> </c:if> </c:forEach> </td> </tr> </table> 其中View_User.Dept.DeptId表示USER表与DEPT表的一个关系(外键) 你就可以看到所显示的列表了。 还有如果在修改用户时,则也与上面的差不多,首先在ACTION当中加入: String ModifyUserId = request.getParameter("GroupUserId"); if (ModifyUserId == null && ModifyUserId.equals("")) { //这是出错处理 request.setAttribute("UserMsg", "User.ValidateUser"); return mapping.findForward("Fail"); } DynaValidatorForm UserActionForm = (DynaValidatorForm) form; User user = UserDAO.GetUser(ModifyUserId); List GetAllDept = UserDAO.GetAllDept();//取得所有部门 request.setAttribute("View_Dept", GetAllDept); UserActionForm.set("User", User); 然后页面当中显示如下(部门为LISTBOX),例子当中只显示部门 <html:select property="DeptAsString"> <c:forEach items="${View_Dept}" var="View_Dept"> <c:choose> <c:when test="${User.Dept.DeptId==View_Dept.DeptId}"> <option value="<c:out value='${View_Dept.DeptId}' />"selected> <c:out value="${View_Dept.DeptName}" /> </option> </c:when> <c:otherwise> <option value="<c:out value='${View_Dept.DeptId}' />"> <c:out value="${View_Dept.DeptName}" /></option> </c:otherwise> </c:choose> </c:forEach> </html:select> 可以看到HTML的SELECT有一个DeptAsString,你可以在FORM当中指定一个STRING的FORM属性。 这样用户的要求就可以完成了。 本次只说明方法,而代码没有经过测试。希望大家多多观注我的BLOG,下一次将臭骂ACTIONFROM不支持的DATE类型及解决方法。 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2006-09-25
在已经成型的框架上进行开发,证明该框架有可取之处,我们只有选择与不选择之间进行选择,而没有任何资格与权利去“臭骂”任何一项技术的存在,如果真的用到“臭骂”时,那估计你应该有出一种更好的框架的能力,而且已经广泛使用中。用了别人的东西,还再骂别人的东西不好,估计此类人物不在少数
|
|
返回顶楼 | |
发表时间:2006-09-25
我百分之九十的时候采用struts自带的标签,百分之五使用jstl,剩余的就使用纯jsp代码。
struts标签开始的时候确实不太好用,不过只要熟悉了他的特性,还是很不错的。 他最大的缺憾可能就是嵌套支持的太不能让人满意了 |
|
返回顶楼 | |
发表时间:2006-09-26
自从我学习使用这些标签开始,我都没觉得这些玩意对我有多少用处。JSP能处理的,他换了一个方式,看上去少写点东西,其实多增加了额外的负担。对于我,已经大量使用JAVA类封装JSP逻辑了,JSP代码本来就很少,用不着再搞个标签来增加可读性。
So,我现在是基本不用标签。也许,对于美工什么的能觉得好些?不过我们的项目中,不是没有美工,就是美工只管图片,不负责网页设计。 |
|
返回顶楼 | |
发表时间:2006-09-26
Lucas Lee 写道 自从我学习使用这些标签开始,我都没觉得这些玩意对我有多少用处。JSP能处理的,他换了一个方式,看上去少写点东西,其实多增加了额外的负担。对于我,已经大量使用JAVA类封装JSP逻辑了,JSP代码本来就很少,用不着再搞个标签来增加可读性。
呵呵,不知道像List, view这样的情况,在不使用任何jsp代码和标签的情况下,如何封装?
So,我现在是基本不用标签。也许,对于美工什么的能觉得好些?不过我们的项目中,不是没有美工,就是美工只管图片,不负责网页设计。 |
|
返回顶楼 | |
发表时间:2006-09-26
还是要看到积极的一面的。
|
|
返回顶楼 | |
发表时间:2006-09-26
adamzhao 写道 Lucas Lee 写道 自从我学习使用这些标签开始,我都没觉得这些玩意对我有多少用处。JSP能处理的,他换了一个方式,看上去少写点东西,其实多增加了额外的负担。对于我,已经大量使用JAVA类封装JSP逻辑了,JSP代码本来就很少,用不着再搞个标签来增加可读性。
呵呵,不知道像List, view这样的情况,在不使用任何jsp代码和标签的情况下,如何封装?So,我现在是基本不用标签。也许,对于美工什么的能觉得好些?不过我们的项目中,不是没有美工,就是美工只管图片,不负责网页设计。 你的提问是不是有问题?不让使用JSP和标签,那我还用什么写? 我的意思是,用普通的JAVA类封装常用逻辑,用JSP调用它们。 所有的标签功能还不都是JAVA类写的?不会增加功能,只是一种封装而已。 |
|
返回顶楼 | |
发表时间:2006-09-26
标签很少用,基本上不用,宁愿用helper辅助类,如
<%=new Tree(name,DataList)%> |
|
返回顶楼 | |
发表时间:2006-09-26
写java代码还是用标签其实都是一样的,只不过标签已经规范好内部实现了,用起来方便些。我100%用jstl。
|
|
返回顶楼 | |
发表时间:2007-02-08
请问可以帮小弟作个级联的下拉列表吗?也是用的struts+JSTL啊!!
多谢拉! 因为我发现很多人都不会阿!!! |
|
返回顶楼 | |