<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Java學習

    java,spring,structs,hibernate,jsf,ireport,jfreechart,jasperreport,tomcat,jboss -----本博客已經搬家了,新的地址是 http://www.javaly.cn 如果有對文章有任何疑問或者有任何不懂的地方,歡迎到www.javaly.cn (Java樂園)指出,我會盡力幫助解決。一起進步

     

    JSF導航文件如何設置實例解析

    The JavaServer Faces (JSF)的Navigation框架提供了一些導航規則,可以使您在設計網站應用程序時定義view(大部分是JSP頁面)之間的頁面導航。這些規則和 其他一些設置一起定義在JSF配置文件中。該文件的名稱一般是 faces-config.xml 。不過完全可以把這個文件名改成其他名字,甚至可以用多個配置文件來存放相關的JSF配置信息,只要在web.xml文件中進行類似下面的設置:

    Code:

    <context-param> 
    <param-name>
    javax.faces.CONFIG_FILES
    </param-name>
    <param-value>
    /WEB-INF/faces-config.xml,
    /WEB-INF/faces-beans.xml
    </param-value>
    </context-param>

    一個簡單的例子

    一個導航規則的構成其實很簡單,讓我們來看第一個例子:

    Code:

    <navigation-rule> 
    <from-view-id>
    /pages/inputname.jsp
    </from-view-id>
    <navigation-case>
    <from-outcome>sayHello</from-outcome>
    <to-view-id>
    /pages/greeting.jsp
    </to-view-id>
    </navigation-case>
    <navigation-case>
    <from-outcome>sayGoodbye</from-outcome>
    <to-view-id>
    /pages/goodbye.jsp
    </to-view-id>
    </navigation-case>
    </navigation-rule>

    這段代碼規定了名為 /pages/inputname.jsp view的兩個輸出(outcomes), sayHello 和 sayGoodbye ,它們分別同特定的頁面相關聯。設置一個默認的輸出事件(Outcome Case)

    基本結構很簡單,但是可以在這個基礎在進行很多變化。請看下一段代碼:

    Code:

    <navigation-rule> 
    <from-view-id>
    /pages/inputname.jsp
    </from-view-id>
    <navigation-case>
    <from-outcome>sayHello</from-outcome>
    <to-view-id>
    /pages/greeting.jsp
    </to-view-id>
    </navigation-case>
    <navigation-case>
    <to-view-id>
    /pages/goodbye.jsp
    </to-view-id>
    </navigation-case>
    </navigation-rule>

    該段代碼同上面的代碼非常類似,不同的是在第二個 navigation-case 中缺少了 from-outcome元素。這意味著所有除sayHello之外的outcome都將進入/pages/goodbye.jsp頁面。

    利用模式

    JSF的navigation模型允許我們利用模式(patterns)。這些模式有一個以星號“*”結尾的字符串組成。參見下例:

    Code:

    <navigation-rule> 
    <from-view-id>/pages/*</from-view-id>
    <navigation-case>
    <from-outcome>menu</from-outcome>
    <to-view-id>/menu/main_main.jsp</to-view-id>
    </navigation-case>
    <navigation-case>
    <from-outcome>info</from-outcome>
    <to-view-id>/menu/info.html</to-view-id>
    </navigation-case>
    </navigation-rule>

    這段導航規則適用于類似 /pages/exit.jsp 之類的任何以 /pages/ 為起始URL的頁面。注意星號一定要放在最后。例如一個類似 / pages/*.jsp 的模式是無效的。

    Resolving More Than One Matching Rule

    現在我們來細察一下JSF導航模型中該如何處理多個規則。具體見下面例子:

    Code:

    <navigation-rule> 
    <from-view-id>/pages/*</from-view-id>
    <navigation-case>
    <from-outcome>info</from-outcome>
    <to-view-id>/menu/generalHelp.html</to-view-id>
    </navigation-case>
    </navigation-rule>

    <navigation-rule>
    <from-view-id>/pages/login.jsp</from-view-id>
    <navigation-case>
    <from-outcome>info</from-outcome>
    <to-view-id>/menu/loginHelp.html</to-view-id>
    </navigation-case>
    </navigation-rule>

    該例中,第二個導航規則,而不是前一個,將對 /pages/login.jsp 生效,盡管該頁面也匹配第一個規則中的模式 /pages/* 。這說明對于一個特定的 from-outcome ,匹配更為具體的規則將生效。

    "Global" Outcomes

    假設現在我們需要一個globalHelp輸出(outcome) 可以使得從任何頁面轉到幫助頁面 /help/index.html 。要實現該效果,可以利用下面兩個聲明中的任何一個:

    Code:

    <navigation-rule> 
    <from-view-id>*</from-view-id>
    <navigation-case>
    <from-outcome>globalhelp</from-outcome>
    <to-view-id>
    /menu/generalHelp.html
    </to-view-id>
    </navigation-case>
    </navigation-rule>
    <navigation-rule>
    <navigation-case>
    <from-outcome>globalhelp</from-outcome>
    <to-view-id>
    /menu/generalHelp.html
    </to-view-id>
    </navigation-case>
    </navigation-rule>

    第一段代碼在標簽 from-view-id 中使用了星號,而第二斷代碼甚至根本沒有用from-view-id標簽。兩者都可以達到相同的效果。不過需注意的是,一個空的from-view-id元素是沒有任何效果的,例如:

    Code:

    <navigation-rule> 
    <from-view-id></from-view-id>
    <navigation-case>
    <from-outcome>
    globalhelp
    </from-outcome>
    <to-view-id>
    /menu/generalHelp.html
    </to-view-id>
    </navigation-case>
    </navigation-rule>

    規則的沖突

    這是個有趣的問題。如果有兩個相同的 from-view-id ,其包含from-outcome也相同,只是指向不同的頁面。來看看下一個例子:

    Code:

    <navigation-rule> 
    <from-view-id>*</from-view-id>
    <navigation-case>
    <from-outcome>
    globalhelp
    </from-outcome>
    <to-view-id>
    /menu/generalHelp.html
    </to-view-id>
    </navigation-case>
    </navigation-rule>

    <navigation-rule>
    <from-view-id>*</from-view-id>
    <navigation-case>
    <from-outcome>
    globalhelp
    </from-outcome>
    <to-view-id>
    /pages/goaway.html
    </to-view-id>
    </navigation-case>
    </navigation-rule>

    這種情況下,最后一個規則將生效。同時還需注意本文前面提到可以將JSF配置信息置于多個文 件中的情況。從而產生沖突的規則可能位于不同的配置文件,此時應根據 web.xml 文件中的JSF配置文件列表,在含沖突規則的配置文件中最后加載的文件中的相關規則將會生效。將一個導航規則分開為幾部分,這是同一種效果的不同實現方 式。試比較下面兩段代碼:

    Code:

    <navigation-rule> 
    <from-view-id>
    /pages/inputname.jsp
    </from-view-id>
    <navigation-case>
    <from-outcome>sayHello</from-outcome>
    <to-view-id>
    /pages/greeting.jsp
    </to-view-id>
    </navigation-case>
    <navigation-case>
    <from-outcome>
    sayGoodbye
    </from-outcome>
    <to-view-id>
    /pages/goodbye.jsp
    </to-view-id>
    </navigation-case>
    </navigation-rule>

    Code:

    <navigation-rule> 
    <from-view-id>
    /pages/inputname.jsp
    </from-view-id>
    <navigation-case>
    <from-outcome>
    sayHello
    </from-outcome>
    <to-view-id>
    /pages/greeting.jsp
    </to-view-id>
    </navigation-case>
    <navigation-rule>
    ...
    ...
    <navigation-rule>
    <from-view-id>
    /pages/inputname.jsp
    </from-view-id>
    <navigation-case>
    <from-outcome>
    sayGoodbye
    </from-outcome>
    <to-view-id>
    /pages/goodbye.jsp
    </to-view-id>
    </navigation-case>

    運行時兩者效果相同。不過,第二段代碼顯示規則聲明可以任意分開后放在配置文件的不同位置, 甚至是不同的配置文件中。你可以根據自己的需要選擇不同的方式。在action中使用導航規則。現在,該看看如何將前面所學內容應用于程序中了。下面便是 一個JSP頁面可能包含的代碼:

    Code:

    <h:commandButton 
    id="submit"
    action="sayHello"
    value="Submit" />

    action屬性值將被用作一個輸出(outcome)。這里是另一種方式:

    Code:

    <h:commandButton id="submit" 
    action="#{GetNameBean.helloAction}"
    value="Submit" />

    這意味著將調用GetNameBean的helloAction方法,該方法運行的結果將成為一個outcome。注意helloAction必須是一個返回值為字符串的public方法。

    上面兩種不同action屬性值的寫法區別在考慮到配置文件中的一個標簽時將比較重要,這個標簽便是 from-action 標簽,我們前面還未提及。請參考下面代碼:

    Code:

    <navigation-rule> 
    <from-view-id>
    /pages/inputname.jsp
    </from-view-id>
    <navigation-case>
    <from-outcome>sayHello</from-outcome>
    <to-view-id>
    /pages/anotherhello.jsp
    </to-view-id>
    </navigation-case>
    <navigation-case>
    <from-action>
    #{GetNameBean.helloAction}
    </from-action>
    <from-outcome>sayHello</from-outcome>
    <to-view-id>
    /pages/hello.jsp
    </to-view-id>
    </navigation-case>
    </navigation-rule>

    在這段代碼中,兩個navigation cases均含有相同的 from-view-id 以及 from-outcome 元素,不過第二個navigation case包含一個from-action元素。如果 sayHello 這個outcome是通過 GetNameBean.helloAction 產生的話,第二個navigation case將生效,不過其原因僅僅是除 from-outcome 外兩者具有相同的優先級。

    Review

    為了檢查您對本文的理解情況。請看下面例子,在 /pages/inputname.jsp 這頁面中對commandButton有一下聲明:

    Code:

    <h:commandButton id="submit" 
    action="#{GetNameBean.helloAction}"
    value="Submit" />

    而JSF配置文件則包含了一下內容:

    Code:

    <navigation-rule> 
    <from-view-id>
    /pages/inputname.jsp
    </from-view-id>
    <navigation-case>
    <from-outcome>sayHello</from-outcome>
    <to-view-id>/a.jsp</to-view-id>
    </navigation-case>
    </navigation-rule>

    <navigation-rule>
    <from-view-id>/pages/*</from-view-id>
    <navigation-case>
    <from-action>
    #{GetNameBean.helloAction}
    </from-action>
    <from-outcome>sayHello</from-outcome>
    <to-view-id>/b.jsp</to-view-id>
    </navigation-case>
    </navigation-rule>

    如果上面頁面中的提交按鈕被按下,到底跳到/a.jsp還是/b.jsp的哪個頁面,如果在GetNameBean.helloAction返回值為sayHello的情況下又如何呢? 留給大家作為思考吧!我
    將在下一文章中公布答案,歡迎大家對我的支持!

    posted on 2008-07-25 12:56 找個美女做老婆 閱讀(230) 評論(0)  編輯  收藏


    只有注冊用戶登錄后才能發表評論。


    網站導航:
     

    導航

    統計

    公告

    本blog已經搬到新家了, 新家:www.javaly.cn
     http://www.javaly.cn

    常用鏈接

    留言簿(6)

    隨筆檔案

    文章檔案

    搜索

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 69xx免费观看视频| 亚洲AV人无码综合在线观看| 一本岛v免费不卡一二三区| 亚洲成AV人片在线观看WWW| 精品女同一区二区三区免费站| 中文字幕精品三区无码亚洲| 在线亚洲精品福利网址导航| 69av免费视频| a毛片视频免费观看影院| 中中文字幕亚洲无线码| 亚洲精品国产精品乱码不99| 野花高清在线观看免费完整版中文 | 国产好大好硬好爽免费不卡| 亚洲精华国产精华精华液网站| 在线A亚洲老鸭窝天堂| 永久免费视频v片www| 久久精品毛片免费观看| 曰批全过程免费视频观看免费软件| 亚洲产国偷V产偷V自拍色戒| 日韩免费高清视频网站| 91精品免费在线观看| 青青青国产手机频在线免费观看| 亚洲精品美女久久久久久久| 亚洲欧洲自拍拍偷午夜色| 亚洲va久久久噜噜噜久久狠狠| 久久国产成人亚洲精品影院 | 亚洲精品一区二区三区四区乱码| 亚洲午夜日韩高清一区| 免费又黄又爽的视频| 在线免费观看一级毛片| 精品国产亚洲第一区二区三区| 久久亚洲精品国产精品婷婷| 亚洲最大免费视频网| 久久久久亚洲精品成人网小说| 亚洲女初尝黑人巨高清| 亚洲AV永久无码区成人网站| 亚洲精品无码午夜福利中文字幕| 亚洲色偷拍另类无码专区| 国产AV无码专区亚洲AV毛网站| 亚洲国产一成人久久精品| 亚洲av无码av制服另类专区|