第六章 使用DispatchAction控制器 1)使用DispatchAction控制器。可以让一个控制器执行几个相同或相似的操作,而不用写多个控制器 2)比如:一个注册表单同时有两个提交按钮。一个提交按钮用来检查用户名是否存在,一个提交按钮 用来执行注册功能,一般情况下会用两个控制器。但是可以通过DispatchAction来实现只用一个控 制器 3)实现DispatchAction的步骤: 1)创建一个Action此Action一定要继承自org.apache.struts.actions.DispatchAction 2)删除里面的Excute方法(一定要删除) 3)在里面加上若干个方法。其参数形式与Excute一样,只不过名字不一样 public ActionForward check(ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response) { 在此执行check方法 } public ActionForward register(ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response) { 在此执行register方法 } 4)在struts-config.xml文件中。配置Action通过参数来决定执行那些方法 <action path="/MyDispatchAction" type="MyDispatchAction" parameter="method"/> 上面配置了一个parameter="method"表明Action会通过该参数的值调用对应的方法。也就是 此Action会根据method的值来决定调用那个方法。如果method的值是"check"则调用check方法 如果method的值是"register"则调用register方法 5)然后在jsp页面中增加method参数值 A)如果是post提交,则可以使用隐藏域来实现 <html:form action="MyDispatchAction.do"> <input type="hidden" name="method" value="register"/> <html:text property="uid"/><html:submit onclick="method.value='check'"/> <html:text property="pwd"/><br> <html:submit onclick="method.value='register'">提交</html:submit> </html:form> 上面用了两个提交按钮,用了一个隐藏域。然后由提交按钮的单击事件中动态改变隐藏 域的值 B:如果是get提交。则可以使用形如: <a href="MyDispatchAction.do?action=check&uid=chen">检查</a> <a href="MyDispatchAction.do?method=register&uid=chen">注册</a> 注意get提交千万不能带有空格 <a href="MyDispatchAction.do?action=check & uid=chen">检查</a>(错误错误) 应用举例: 1)添加与修改(添加与修改经常会共用一个表单,所以可以使用DispatchAction 2)检查用户名是否存在与注册 3)一个按钮用于根据工号查询,一个按钮用于把查询之后的结果进行修改 4)一个页面放入四个按钮。实现加减乘除 第七章 使用struts中的tiles框架技术使用模板页 1)在开发Web应用程序时,常常要求同一个站点的所有Web页面保持一致的外观。比如 --------------------------------- | | | | | header | | |------------------------- | Menu | | | | content | | | | | |------------------------ | | | | | footer | | | | | | | --------------------------------- 2)对同一个站点的所有页面,只有content部分的内容不同,如果采用基本的jsp语句来编 写所有web页面。显示会导致大量的重复编码,增加开发和维护成本,我们完全可以把 其中不变的部分定义为模板。以后只要使用模板就行了 3)struts中的tiles框架提供了这样一种模板页的实现方案 4)tiles具体实现步骤: A:做一个模板页。该模板页包括头,左边,顶边 model.jsp。 注意: 整个表格:800*600 左边宽:20% 右边宽:80%,高80% 顶边高:10% 底边高:10% B:去掉其中的<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">的标记 C:在model.jsp中待插入内容页的地方用<tiles:insert attribute="content"/>标记指定 待插入的内容,属性名为"content" <tr> <td width="80%" height="90%">***<tiles:insert attribute="content"/>****</td> </tr> D:创建一个内容页。注意一定要去掉其中的html标记与body标记。因为模板页中已经定义了 html标记。如果去掉了body标记不好排版。可以使用表格进行排版 一般命名为:XXXContent.jsp。比如:workerAddContent.jsp。如果有样式则要取一个 不同于其它的样式的别名 E:把内容页与模板页合在一起做成一个组件 1)在WEB-INF下面创建一个xml配置文件。取名为tiles-defs.xml 2)写在如下内容: <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE component-definitions PUBLIC "-//Apache Software Foundation//DTD Tiles Configuration 1.1//EN" "tiles-config_1_1.dtd" > <component-definitions> //定义多个definitions组件 <definition name="add-defin" path="/model.jsp"> //这是模板页 <put name="content" value="addContent.jsp"/> //name的值一定要与模板页中定义的<tiles:insert attribute="content"/>一致 //value写上内容页 </definition> ..... <definition name="XXX" path="/XXX.jsp"> 定义多个组件 <put name="XXX" value="XXX.jsp"/> //name的值一定要与模板页中定义的<tiles:insert attribute="content"/>一致 //value写上内容页 </definition> </component-definitions> 3)在struts-config.xml中配置 </plug-in> <plug-in className="org.apache.struts.tiles.TilesPlugin"> <set-property property="definitions-config" value="/WEB-INF/tiles-defs.xml"/> //此处的名字一定要与前同创建的 //tiles-defs配置文件名一致 </plug-in> 4)在结果页中: <%@ page contentType="text/html; charset=gb2312" language="java" import="java.sql.*" errorPage="" %> <%@ taglib uri="http://struts.apache.org/tags-tiles" prefix="tiles" %> <tiles:insert definition="add-defin" /> //此处的名字一定要与在tiles-defs中定义的组件 //name保持一致

评论