您好,登錄后才能下訂單哦!
這篇文章將為大家詳細(xì)講解有關(guān)NetBeans Struts中的頁(yè)面布局是怎樣的,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。
在以前的開(kāi)發(fā)過(guò)程中,我常常遭遇這樣的經(jīng)歷,要完成某個(gè)任務(wù),首先由頁(yè)面設(shè)計(jì)人員來(lái)設(shè)計(jì)頁(yè)面原型,再交給程序員進(jìn)行處理。很多情況下,我們總是要整理一個(gè)完整的頁(yè)面。事實(shí)上,我們做了太多的重復(fù)工作。很多頁(yè)面的結(jié)構(gòu)是完全相同的,頁(yè)面的頭,尾,導(dǎo)航菜單都是相同的,只是主體內(nèi)容部分不同而已。重復(fù)整理這些相同的部分是一個(gè)不小的負(fù)擔(dān),我們很自然的想到,要是這些頁(yè)面元素能夠復(fù)用就會(huì)省下很多事。
Struts 內(nèi)置了Tiles,利用它可以很好復(fù)用頁(yè)面,使用起來(lái)就像我們復(fù)用類一樣。
使用Tiles
在以前的開(kāi)發(fā)過(guò)程中,我常常遭遇這樣的經(jīng)歷,要完成某個(gè)任務(wù),首先由頁(yè)面設(shè)計(jì)人員來(lái)設(shè)計(jì)頁(yè)面原型,再交給程序員進(jìn)行處理。很多情況下,我們總是要整理一個(gè)完整的頁(yè)面。事實(shí)上,我們做了太多的重復(fù)工作。很多頁(yè)面的結(jié)構(gòu)是完全相同的,頁(yè)面的頭,尾,導(dǎo)航菜單都是相同的,只是主體內(nèi)容部分不同而已。重復(fù)整理這些相同的部分是一個(gè)不小的負(fù)擔(dān),我們很自然的想到,要是這些頁(yè)面元素能夠復(fù)用就會(huì)省下很多事。
Struts 內(nèi)置了Tiles,利用它可以很好復(fù)用頁(yè)面,使用起來(lái)就像我們復(fù)用類一樣。
使用Tiles
1.如果頁(yè)面內(nèi)容對(duì)頁(yè)面進(jìn)行劃分,一個(gè)頁(yè)面可以分成很多塊,如header , footer , menu, content,等,如果新聞門戶網(wǎng)站,content可以進(jìn)一步細(xì)分,footall, entertainment, 等。
這里僅僅作演示,我將頁(yè)面分header , footer ,content。
展開(kāi)Configuration Files,打開(kāi)tile-defs.xml,定義一個(gè)最本的頁(yè)面模板,其它頁(yè)面在這個(gè)基礎(chǔ)上進(jìn)行擴(kuò)充(這有點(diǎn)像定義一個(gè)基類,其它則子類繼承基類,以獲得基類的特性)。
﹤definition name=".mainLayout" path="/layouts/default.jsp">﹤put name="title" value="Struts Demo Application" />﹤put name="header" value="/layouts/header.jsp" />﹤put name="footer" value="/layouts/footer.jsp" />﹤put name="body" value=".portal.body" />﹤/definition> |
其它頁(yè)面以這個(gè)為基礎(chǔ),繼承這個(gè)模板內(nèi)容,可以重新定義title和body內(nèi)容。
﹤definition name="logonPage" extends=".mainLayout">﹤put name="title" value="Logon Page" />﹤put name="body" value="/layouts/logonBody.jsp" />﹤/definition>﹤definition name="registerPage" extends=".mainLayout">﹤put name="title" value="New Registeration " />﹤put name="body" value="/layouts/registerBody.jsp" />﹤/definition>﹤definition name="indexPage" extends=".mainLayout">﹤put name="title" value="Home Page " />﹤put name="body" value="/layouts/indexBody.jsp" />﹤/definition>﹤definition name="registeredSuccessPage" extends=".mainLayout">﹤put name="title" value="Registered Successfully" />﹤put name="body" value="/layouts/registerSuccessBody.jsp" />﹤/definition> |
事實(shí),這和Java中類的繼承非常類似。
2.相應(yīng)的jsp頁(yè)面,在Web pages下新建一個(gè)layouts目錄。默認(rèn)模板(即default.jsp)內(nèi)容如下。
﹤html>﹤head>﹤meta http-equiv="Content-Type" content="text/html; charset=UTF-8">﹤title>﹤tiles:getAsString name="title"/>﹤/title>﹤/head>﹤body>﹤div id="header">﹤tiles:insert attribute="header"/>﹤/div>﹤div id="content">﹤tiles:insert attribute="body"/>﹤/div>﹤div id="footer">﹤tiles:insert attribute="footer"/>﹤/div>﹤/body>﹤/html> |
其中,getAsString表示title以一個(gè)字符串的形式插入模板。
header.jsp中定義了頁(yè)面標(biāo)題。
﹤%@page contentType="text/html"%>﹤%@page pageEncoding="UTF-8"%>﹤div>﹤h2>Struts Demo Application﹤/h2>﹤/div> |
footer.jsp內(nèi)容版本聲明,如下:
﹤%@page contentType="text/html"%>﹤%@page pageEncoding="UTF-8"%>﹤div>Copyright 2007© hantsy<hantsy@tom.com>﹤/div> |
其它頁(yè)面,各復(fù)制一份到layouts目錄中,頁(yè)面只留body之間的內(nèi)容。
如indexBody.jsp內(nèi)容如下:
|
3.修改Struts配置文件,將所有jsp文件路徑替換成tile配置文件中定義的名稱。
﹤action-mappings>﹤action path="/logout" type="com.myapp.web.LogoutAction"/>﹤action input="registerPage" name="UserForm" path="/register" scope="session" type="com.myapp.web.RegisterAction">﹤forward name="success" path="registeredSuccessPage"/>﹤/action>﹤action input="logonPage" name="UserForm" path="/logon" scope="session" type="com.myapp.web.LogonAction"/>﹤action path="/index" forward="indexPage"/>﹤action path="/newLogon" forward="logonPage"/>﹤action path="/newRegister" forward="registerPage"/>﹤/action-mappings> |
值得注意的是,使用Tile必須的兩個(gè)最重要的配置,NetBeans在創(chuàng)建項(xiàng)目時(shí)已經(jīng)幫我們自動(dòng)完成了。
一個(gè)是注冊(cè)Tile插件,打開(kāi)Struts配置文件struts-config.xml我們就可以看到。
﹤plug-in className="org.apache.struts.tiles.TilesPlugin" >﹤set-property property="definitions-config" value="/WEB-INF/tiles-defs.xml" />﹤set-property property="moduleAware" value="true" />﹤/plug-in> |
另外一個(gè)是,重新定義controller,將processorClass改成使用 org.apache.struts.tiles.TilesRequestProcessor。
﹤controller processorClass="org.apache.struts.tiles.TilesRequestProcessor"/>
4.運(yùn)行項(xiàng)目進(jìn)行測(cè)試。
使用Sitemesh
Sitemesh是www.opensymphony.org帶來(lái)的另一款優(yōu)秀的頁(yè)面布局工具。它不專門針對(duì)Struts ,甚至其它語(yǔ)言的web程序也可以使用它。
它使用Decorator模式達(dá)到預(yù)期效果。這里可以將頁(yè)面分為兩類,decorator(修飾)和decoratored(被修飾)。這就好比有一個(gè)相框和各種不同可以用來(lái)變換的相片,當(dāng)相框中放入不同的相片,就得到不同的視覺(jué)效果。
1.下載并安裝Sitemesh。
從www.opensymphony.org下載最新的sitemesh 2.3,解壓到硬盤(pán)。
將﹤sitemesh>/lib下的common- collections.jar,freemarker.jar, velocity-deps-1.3.1.jar,velocity-tools-view-1.3.1.jar 和﹤sitemesh>/dist下sitemesh-2.3.jar添加到項(xiàng)目Libraries中。
將﹤sitemesh>\src\etc\tld\jsp1.2的sitemesh-decorator.tld和sitemesh-page.tld復(fù)制一份到項(xiàng)目的web/WEB-INF/下面。
2.配置sitemesh。
從configurations中打開(kāi)web.xml,定義Sitemesh Filter。
﹤filter>﹤filter-name>sitemesh﹤/filter-name>﹤filter-class>com.opensymphony.module.sitemesh.filter.PageFilter ﹤/filter-class>﹤/filter>﹤filter-mapping>﹤filter-name>sitemesh﹤/filter-name>﹤url-pattern>/*﹤/url-pattern>﹤/filter-mapping> |
在web/WEB-INF在定義兩個(gè)基本的sitemesh配置文件,這兩個(gè)文件可以sitemesh包復(fù)制過(guò)來(lái)。
sitemesh.xml定義最基本的應(yīng)用規(guī)則。
﹤sitemesh>﹤property name="decorators-file" value="/WEB-INF/decorators.xml"/>﹤excludes file="${decorators-file}"/>﹤page-parsers>﹤parser content-type="text/html" class="com.opensymphony.module.sitemesh.parser.HTMLPageParser" />﹤/page-parsers>﹤decorator-mappers>﹤mapper class="com.opensymphony.module.sitemesh.mapper.PageDecoratorMapper">﹤param name="property.1" value="meta.decorator" />﹤param name="property.2" value="decorator" />﹤/mapper>﹤mapper class="com.opensymphony.module.sitemesh.mapper.FrameSetDecoratorMapper">﹤/mapper>﹤mapper class="com.opensymphony.module.sitemesh.mapper.AgentDecoratorMapper">﹤param name="match.MSIE" value="ie" />﹤param name="match.Mozilla [" value="ns" />﹤param name="match.Opera" value="opera" />﹤param name="match.Lynx" value="lynx" />﹤/mapper>﹤mapper class="com.opensymphony.module.sitemesh.mapper.PrintableDecoratorMapper">﹤param name="decorator" value="printable" />﹤param name="parameter.name" value="printable" />﹤param name="parameter.value" value="true" />﹤/mapper>﹤mapper class="com.opensymphony.module.sitemesh.mapper.RobotDecoratorMapper">﹤param name="decorator" value="robot" />﹤/mapper>﹤mapper class="com.opensymphony.module.sitemesh.mapper.ParameterDecoratorMapper">﹤param name="decorator.parameter" value="decorator" />﹤param name="parameter.name" value="confirm" />﹤param name="parameter.value" value="true" />﹤/mapper>﹤mapper class="com.opensymphony.module.sitemesh.mapper.FileDecoratorMapper">﹤/mapper>﹤mapper class="com.opensymphony.module.sitemesh.mapper.ConfigDecoratorMapper">﹤param name="config" value="${decorators-file}" />﹤/mapper>﹤/decorator-mappers>﹤/sitemesh> |
decorators.xml中定義具體的decortor應(yīng)用規(guī)則。
|
3.定義Decorator。
在Web Pages下新建一個(gè)目錄,命名為decorators,在這個(gè)新建的目錄中新建main.jsp,作為主要的decorator。
﹤%@page contentType="text/html"%>﹤%@page pageEncoding="UTF-8"%>﹤%@ taglib uri="http://www.opensymphony.com/sitemesh/decorator" prefix="decorator" %>﹤%@ taglib uri="http://www.opensymphony.com/sitemesh/page" prefix="page" %>﹤html>﹤head>﹤title>Demo-﹤decorator:title default="Struts Sitemesh Demo..." />﹤/title>﹤!--link href="﹤%= request.getContextPath() %>/decorators/main.css" rel="stylesheet" type="text/css"-->﹤decorator:head />﹤/head>﹤body>﹤div>﹤table width="100%">﹤tr>﹤td id="pageTitle">﹤h2> ﹤decorator:title />﹤/h2>﹤/td>﹤/tr>﹤tr>﹤td valign="top" height="100%">﹤decorator:body />﹤/td>﹤/tr>﹤tr>﹤td id="footer">﹤page:applyDecorator page="/footer.html" name="panel" />﹤/td>﹤/tr>﹤/table>﹤/div>﹤/body>﹤/html> |
另外再定義一個(gè)panel。
|
文件中,decorator:title和decorator:body定義要被替換的內(nèi)容位置,應(yīng)用之后,分別替換成decoratored頁(yè)面的title和body標(biāo)簽中間的內(nèi)容。
下面將Web Pages下的頁(yè)面恢復(fù)成原貌。如index.jsp內(nèi)容如下。
|
同時(shí)還要修改Struts定義文件,將上一節(jié)中tiles定義的page名稱全部還要成具體的頁(yè)面路徑。
﹤action-mappings>﹤action path="/logout" type="com.myapp.web.LogoutAction"/>﹤action input="/register.jsp"name="UserForm"path="/register"scope="session"type="com.myapp.web.RegisterAction">﹤forward name="success" path="/registerSuccess.jsp"/>﹤/action>﹤action input="/logon.jsp"name="UserForm"path="/logon"scope="session"type="com.myapp.web.LogonAction"/>﹤action path="/Welcome" forward="/welcomeStruts.jsp"/>﹤action path="/index" forward="/index.jsp"/>﹤action path="/newLogon" forward="/logon.jsp"/>﹤action path="/newRegister" forward="/register.jsp"/>﹤/action-mappings> |
另外還要禁用tiles,以免和sitemesh發(fā)生沖突。注釋掉controller定義,讓Struts使用默認(rèn)的requestProcessor。
關(guān)于NetBeans Struts中的頁(yè)面布局是怎樣的就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。