NetBeansStruts中的頁面布局是怎樣的

這篇文章將為大家詳細講解有關NetBeans Struts中的頁面布局是怎樣的,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

10年的永城網(wǎng)站建設經驗,針對設計、前端、開發(fā)、售后、文案、推廣等六對一服務,響應快,48小時及時工作處理。營銷型網(wǎng)站的優(yōu)勢是能夠根據(jù)用戶設備顯示端的尺寸不同,自動調整永城建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設計,從而大程度地提升瀏覽體驗。創(chuàng)新互聯(lián)公司從事“永城網(wǎng)站設計”,“永城網(wǎng)站推廣”以來,每個客戶項目都認真落實執(zhí)行。

在以前的開發(fā)過程中,我常常遭遇這樣的經歷,要完成某個任務,首先由頁面設計人員來設計頁面原型,再交給程序員進行處理。很多情況下,我們總是要整理一個完整的頁面。事實上,我們做了太多的重復工作。很多頁面的結構是完全相同的,頁面的頭,尾,導航菜單都是相同的,只是主體內容部分不同而已。重復整理這些相同的部分是一個不小的負擔,我們很自然的想到,要是這些頁面元素能夠復用就會省下很多事。

Struts 內置了Tiles,利用它可以很好復用頁面,使用起來就像我們復用類一樣。

使用Tiles

在以前的開發(fā)過程中,我常常遭遇這樣的經歷,要完成某個任務,首先由頁面設計人員來設計頁面原型,再交給程序員進行處理。很多情況下,我們總是要整理一個完整的頁面。事實上,我們做了太多的重復工作。很多頁面的結構是完全相同的,頁面的頭,尾,導航菜單都是相同的,只是主體內容部分不同而已。重復整理這些相同的部分是一個不小的負擔,我們很自然的想到,要是這些頁面元素能夠復用就會省下很多事。

Struts 內置了Tiles,利用它可以很好復用頁面,使用起來就像我們復用類一樣。

使用Tiles

1.如果頁面內容對頁面進行劃分,一個頁面可以分成很多塊,如header , footer , menu, content,等,如果新聞門戶網(wǎng)站,content可以進一步細分,footall, entertainment, 等。

這里僅僅作演示,我將頁面分header , footer ,content。

展開Configuration Files,打開tile-defs.xml,定義一個最本的頁面模板,其它頁面在這個基礎上進行擴充(這有點像定義一個基類,其它則子類繼承基類,以獲得基類的特性)。

﹤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>

其它頁面以這個為基礎,繼承這個模板內容,可以重新定義title和body內容。

﹤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>

事實,這和Java中類的繼承非常類似。

2.相應的jsp頁面,在Web pages下新建一個layouts目錄。默認模板(即default.jsp)內容如下。

﹤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以一個字符串的形式插入模板。

header.jsp中定義了頁面標題。

﹤%@page contentType="text/html"%>﹤%@page pageEncoding="UTF-8"%>﹤div>﹤h2>Struts Demo Application﹤/h2>﹤/div>

footer.jsp內容版本聲明,如下:

﹤%@page contentType="text/html"%>﹤%@page pageEncoding="UTF-8"%>﹤div>Copyright 2007&copy; hantsy<hantsy@tom.com>﹤/div>

其它頁面,各復制一份到layouts目錄中,頁面只留body之間的內容。

如indexBody.jsp內容如下:

﹤%@page contentType="text/html"%>

﹤%@page pageEncoding="UTF-8"%>

﹤%@ taglib uri="/WEB-INF/struts-html.tld" prefix="html" %>

﹤%@ taglib uri="/WEB-INF/struts-bean.tld" prefix="bean" %>

﹤%@ taglib uri="/WEB-INF/struts-logic.tld" prefix="logic" %>

﹤h2>Home Page﹤/h2>

Welcome,

﹤logic:notPresent name="username" scope="session">

Guest !﹤html:link forward="newLogon">Logon ﹤/html:link> or

﹤html:link forward="newRegister">Register Now...﹤/html:link>

﹤/logic:notPresent>

﹤logic:present name="username" scope="session">

﹤bean:write name="username" scope="session"/>,

﹤html:link forward="logout">Log Out..﹤/html:link>

﹤/logic:present>

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必須的兩個最重要的配置,NetBeans在創(chuàng)建項目時已經幫我們自動完成了。

一個是注冊Tile插件,打開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>

另外一個是,重新定義controller,將processorClass改成使用 org.apache.struts.tiles.TilesRequestProcessor。

﹤controller processorClass="org.apache.struts.tiles.TilesRequestProcessor"/>

4.運行項目進行測試。

使用Sitemesh

Sitemesh是www.opensymphony.org帶來的另一款優(yōu)秀的頁面布局工具。它不專門針對Struts ,甚至其它語言的web程序也可以使用它。

它使用Decorator模式達到預期效果。這里可以將頁面分為兩類,decorator(修飾)和decoratored(被修飾)。這就好比有一個相框和各種不同可以用來變換的相片,當相框中放入不同的相片,就得到不同的視覺效果。

1.下載并安裝Sitemesh。

從www.opensymphony.org下載最新的sitemesh 2.3,解壓到硬盤。

將﹤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添加到項目Libraries中。

將﹤sitemesh>\src\etc\tld\jsp1.2的sitemesh-decorator.tld和sitemesh-page.tld復制一份到項目的web/WEB-INF/下面。

2.配置sitemesh。

從configurations中打開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在定義兩個基本的sitemesh配置文件,這兩個文件可以sitemesh包復制過來。

sitemesh.xml定義最基本的應用規(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應用規(guī)則。

﹤?xml version="1.0" encoding="ISO-8859-1"?>

﹤decorators defaultdir="/decorators">

﹤!-- Any urls that are excluded will never be decorated by Sitemesh -->

﹤excludes>

﹤pattern>/exclude.jsp﹤/pattern>

﹤pattern>/exclude/*﹤/pattern>

﹤/excludes>

﹤decorator name="main" page="main.jsp">

﹤pattern>/*﹤/pattern>

﹤/decorator>

﹤decorator name="panel" page="panel.jsp"/>

﹤/decorators>

3.定義Decorator。

在Web Pages下新建一個目錄,命名為decorators,在這個新建的目錄中新建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>

另外再定義一個panel。

﹤%@ taglib uri="http://www.opensymphony.com/sitemesh/decorator" prefix="decorator" %>

﹤p>

﹤table width="100%" border=0 cellpadding=0 cellspacing=0>

﹤tr>

﹤td class="panelBody">

﹤decorator:body />

﹤/td>

﹤/tr>

﹤/table>

﹤/p>

文件中,decorator:title和decorator:body定義要被替換的內容位置,應用之后,分別替換成decoratored頁面的title和body標簽中間的內容。

下面將Web Pages下的頁面恢復成原貌。如index.jsp內容如下。

﹤%@page contentType="text/html"%>

﹤%@page pageEncoding="UTF-8"%>

﹤%@ taglib uri="/WEB-INF/struts-html.tld" prefix="html" %>

﹤%@ taglib uri="/WEB-INF/struts-bean.tld" prefix="bean" %>

﹤%@ taglib uri="/WEB-INF/struts-logic.tld" prefix="logic" %>

﹤html>

﹤head>﹤title>HomePage ﹤/title>﹤/head>

﹤body>

Welcome,

﹤logic:notPresent name="username" scope="session">

Guest !﹤html:link forward="newLogon">Logon ﹤/html:link> or

﹤html:link forward="newRegister">Register Now...﹤/html:link>

﹤/logic:notPresent>

﹤logic:present name="username" scope="session">

﹤bean:write name="username" scope="session"/>,

﹤html:link forward="logout">Log Out..﹤/html:link>

﹤/logic:present>

﹤/body>

﹤/html>

同時還要修改Struts定義文件,將上一節(jié)中tiles定義的page名稱全部還要成具體的頁面路徑。

﹤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使用默認的requestProcessor。

關于NetBeans Struts中的頁面布局是怎樣的就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

文章題目:NetBeansStruts中的頁面布局是怎樣的
網(wǎng)頁URL:http://muchs.cn/article44/jojjee.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供、定制開發(fā)商城網(wǎng)站、做網(wǎng)站網(wǎng)站策劃、全網(wǎng)營銷推廣

廣告

聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

營銷型網(wǎng)站建設