在使用jsf框架时,肯定会用到faces-config.xml。 而其中就会出现很多的Navigation项。

其实这些Navigation就是一些页面跳转的东西。

以下内容来自http://blog.sina.com.cn/s/blog_600046120100to0e.html

导航(Navigation)
现在对jsf中的导航进行些小结,分为三部分来说,参考与core jsf
1,静态的导航
2,动态的导航
3,高级的导航
主要讨论在你web程序中如何配置导航,即如何让你的程序从一个页面跳转到下一个页面,当然要根据你业务

逻辑的actions和outcomes。

1,静态导航(Static Navigation)
在一个简单的web应用程序中,页面导航一般是静态指定的,在jsf中你只需要给每个按钮一个action属性,然

后再faces-config.xml中配置以下就可以轻松实现页面之间的跳转问题。
例如:
<h:commandButton label="Login"
action="login"/>
但是这样还不行,action必须匹配在faces-config.xml文件中的导航规则的outcome:
<navigation-rule>

<from-view-id>/index.jsp</from-view-id>

<navigation-case>

<from-outcome>login</from-outcome>

<to-view-id>/welcome.jsp</to-view-id>

</navigation-case>

</navigation-rule>
这表明如果按钮在/index.jsp中被点击,页面将跳转到/welcome.jsp.
注意:这里的view-id必须以"/"开始,扩展名为.jsp。例:如果你把from-view-id设置为/index.faces,将不

能工作。

我们看下面这个导航规则:
<navigation-rule>

<navigation-case>

<from-outcome>logout</from-outcome>

<to-view-id>/logout.jsp</to-view-id>

</navigation-case>

</navigation-rule>

可以看到他没有from-view-id,这就意味着:无论你在整个web程序中的任何页面点击,只要outcome为logout

,她都会跳转到/logout.jsp页面。

我们再看下面这段导航规则:

<navigation-rule>

<from-view-id>/index.jsp</from-view-id>

<navigation-case>

<from-outcome>login</from-outcome>

<to-view-id>/welcome.jsp</to-view-id>

</navigation-case>

<navigation-case>

<from-outcome>signup</from-outcome>

<to-view-id>/newuser.jsp</to-view-id>

</navigation-case>

</navigation-rule>

我们可以看到,她有一个相同的from-view-id,意思就是说在/index.jsp中如果你触发的outcome为login,页面

就会跳转到/welecom.jsp,要是为signup的话就跳转到/newuser.jsp页面。事实上我们会经常用到这种规则的

配置。

注意:如果没有导航规则来匹配一个给定的action,那么当前页面将简单的重新显示一下。

2,动态的导航(Dynamic Navigation)
在大多数web程序中,导航都不是静态的。页面的流程不仅仅依靠你点击的那个按钮,而且还有根据你输入的

内容来判断。最常见的就是提交一个处理登陆的页面,可能有两种结果:success or
failure!结果(outcome)

将依赖于一定的计算判断,譬如用户名和密码是否合法。

为了实现动态的导航,提交按钮必须有一个方法来参考,例如:

<h:commandButton label="Login"
action="#{loginController.verifyUser}"/>
loginController是某个类的受管Bean,这个类必须有一个方法名字是verifyUser,返回一个String,供

action属性使用,这个方法可能是这样:
String verifyUser() {
   if (...)
     
return "success";
   else
     
return "failure";
}
注意:如果一个action method返回null,那么将重新显示页面本身。

3,高级的导航

As you can see from the syntax diagram, each navigation-rule and
navigation-case element can

have arbitrary description, display-name, and icon elements.
These elements are intended for use

in builder tools, and we do not discuss them further.

我们来看下面的导航规则:
<navigation-case>

<from-outcome>success</from-outcome>

<to-view-id>/success.jsp</to-view-id>

<redirect/>

</navigation-case>

你会发现在to-view-id后面多了一个redirect元素,Redirecting the page is slower
than forwarding

because another round trip to the browser is involved. However,
the redirection gives the

browser a chance to update its address field.
注释:没有redirect,原来的url(localhost:8080/javaquiz/index.faces)在你从/index.jsp到/success.jsp

后在地址栏中没有改变,反之改变了,变成了localhost:8080/javaquiz/success.faces。

我们接着看下面的导航规则:
<navigation-rule>

<from-view-id>/secure/*</from-view-id>

<navigation-case>

. . .

</navigation-case>

</navigation-rule>
你会发现from-view-id中使用了通配符(wildcards),/secure目录下面的所有页面将应用导航规则。同理:

<from-view-id>/*</from-view-id>or<from-view-id>*</from-view-id>将应用的所有的页面。

我们再看下面的导航规则:

<navigation-rule>
    
<from-view-id>/index/zhuce/denglu.jsp</from-view-id>

<navigation-case>
      
<from-action>#{LoginBean.doLogin}</from-action>

<from-outcome>success</from-outcome>

<to-view-id>/index/zhuce/welcome.jsp</to-view-id>

</navigation-case>
    
<navigation-case>
<from-action>#{LoginBean.doLogin}</from-action>

<from-outcome>failed</from-outcome>

<to-view-id>/index/zhuce/denglu.jsp</to-view-id>

</navigation-case>
</navigation-rule>
你会发现多了一个<from-action>,上边这个好像不太恰当,因为from-action一般在下面这种情况下才能显示

出灵活性:

That flexibility can be useful if you have two separate actions
with the same action string, or

two action method references that return the same action
string.
如果你有连个单独的actions却有相同的action string或两个相同的action
method返回相同的action

string.
举个例子:answerAction和startOverAction都返回again
<navigation-case>

<from-action>#{quiz.answerAction}</from-action>

<from-outcome>again</from-outcome>

<to-view-id>/again.jsp</to-view-id>

</navigation-case>

<navigation-case>

<from-action>#{quiz.startOverAction}</from-action>

<from-outcome>again</from-outcome>

<to-view-id>/index.jsp</to-view-id>

</navigation-case>

例如,假设在我们的测验程序中,startOverAction返回字符串"again"而不是"Start
Over"。answerAction也可能返回相同的字符串。为了区别两种导航情况,可以使用from-action元素。该元素的内容必须与action属性的方法表达式字符串相同。

 <navigation-case>
<from-action>#{quiz.answerAction}</from-action>
<from-outcome>again</from-outcome>
<to-view-id>/again.jsp</to-view-id>
</navigation-case>
<navigation-case>
<from-action>#{quiz.startOverAction}</from-action>
<from-outcome>again</from-outcome>
<to-view-id>/index.jsp</to-view-id>
</navigation-case>

说明

导航处理程序不会调用#{...}分隔符中的方法。在导航处理程序处理之前,该方法已经被调用。导航处理程序只是使用from-action字符串作为一个主键,用于查找匹配导航的情况

JSF -> 导航(Navigation)的更多相关文章

  1. 【译】UI设计基础(UI Design Basics)--导航(Navigation)(六)

    [译]UI设计基础(UI Design Basics)--导航(Navigation)(六)

  2. 微软BI 之SSRS 系列 - 如何实现报表导航 Navigation 和钻取 Drill Down 的效果

    开篇介绍 如何在 SSRS 报表中实现标签导航 Navigation 和向下钻取 Drill Down的效果? 如同下面这个例子一样 - 在页面第一次加载的时候,默认显示是全部地区的销售总和情况,上面 ...

  3. 从PRISM开始学WPF(八)导航Navigation?

    原文:从PRISM开始学WPF(八)导航Navigation? 0x6Navigation Basic Navigation Prism中的Navigation提供了一种类似导航的功能,他可以根据用户 ...

  4. ABP理论学习之导航(Navigation)

    返回总目录 本篇目录 创建菜单 注册导航提供者 展示菜单 每一个web应用在页面之间都有一些要导航的菜单.ABP提供了公用的基础设施来创建菜单并将菜单展示给用户. 创建菜单 一个应用可能由不同的模块组 ...

  5. 【Unity笔记】寻路导航Navigation中的区域Areas与消耗Cost

    Navigation寻路导航界面下,Areas分页下是在给导航区域分类(相当于分层),以及为每个分类设置不同的消费Cost,意义在于,导航算法中会计算出的是累加起来消耗最低的路径(不一定是视觉上最短可 ...

  6. [UE4]手柄导航 Navigation

    Navigation是对应游戏手柄.Left.Right.Up.Down.Next.Previous分别对应游戏手柄上的左.右.上.下.下一个.上一个按键. Left.Right.Up.Down.Ne ...

  7. JSF Action 与ActionListener的区别

    JSF Action 与ActionListener的区别 标签: 杂谈    事件  检验  参数  事件产生  页面跳转  Action  有 无参数,不传入当前控件,有返回值    当铵钮被单击 ...

  8. JSF标签大全详解

    1. JSF入门 藉由以下的几个主题,可以大致了解JSF的轮廓与特性,我们来看看网页设计人员与应用程序设计人员各负责什么. 1.1简介JSF Web应用程序的开发与传统的单机程序开发在本质上存在着太多 ...

  9. ADF_General JSF系列2_创建JSF类型的页面向导

    2015-02-17 Created By BaoXinjian

随机推荐

  1. Struts2--百度百科

    Struts 2是Struts的下一代产品,是在 struts 1和WebWork的技术基础上进行了合并的全新的Struts 2框架.其全新的Struts 2的体系结构与Struts 1的体系结构差别 ...

  2. python exec和eval

    exec语句用来执行储存在字符串或文件中的Python语句.例如,我们可以在运行时生成一个包含Python代码的字符串,然后使用exec语句执行这些语句.下面是一个简单的例子. >>> ...

  3. Notepad++输入模式之改动模式、插入模式

    notepad++光标是直的,怎样让它变成竖的? 通常光标是竖的.为插入模式,光标在字符之间时输入,内容会随输入的内容向后移动,新输入的内容不会替换后面的内容. 当按一下"Insert&qu ...

  4. android-异步消息处理机制初步

    Android的异步消息处理主要由4个部分组成,Message.Handler.MessageQueue和Looper Message:在线程之间传递的消息,它可以在内部携带少量的信息,用于在不同线程 ...

  5. RabbitMQ快速入门python教程

    摘要:HelloWorld 简介 RabbitMQ:接受消息再传递消息,可以视为一个“邮局”.发送者和接受者通过队列来进行交互,队列的大小可以视为无限的,多个发送者可以发生给一个队列,多个接收者也可以 ...

  6. Android应用TranslateAnimation移动之后,利用视图的setLayoutPara

    Android中利用TranslateAnimation移动时,不设置mTranslateAnimation.setFillAfter(true);,而利用视图的setLayoutParams来重新定 ...

  7. 比isConnected()更靠谱的的获取socket实时连接状态!

    看到这个标题,预计非常多人会说用socket.isConnected()或者socket.isClosed()等方法来推断即可了,但其实这些方法都是訪问socket在内存驻留的状态,当socket和s ...

  8. PV、UV、GMV

    原文地址:电商术语:客单价.UV.PV.转化率.销售额作者:馨闻莲博 UV(独立访客):Unique Visitor,访问您网站的一台电脑客户端为一个访客.00:00-24:00内相同的客户端只会被计 ...

  9. 自己动手制作更好用的markdown编辑器-01

    这里文章都是从个人的github博客直接复制过来的,排版可能有点乱. 原始地址  http://benq.im   文章目录 1. 简介 2. 项目结构 3. 程序主界面 4. 拖动窗口 5. app ...

  10. Atitit.播放系统规划新版本 and 最近版本回顾 v3  pbf.doc

    Atitit.播放系统规划新版本 and 最近版本回顾 v3  pbf.doc 1 版本11 (ing)4 1.1 规划h5本地缓存系列 4 1.2 Android版本app4 1.3 双类别系统, ...