论坛首页 Java企业应用论坛

JSF入门笔记

浏览 4958 次
锁定老帖子 主题:JSF入门笔记
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2008-10-12  

首先简单的理解一下JSF的工作方式



 

六个阶段分别为:

l         恢复视图:也称为重建组件树,在服务器端生成页面上的对象等操作。

l         应用请求值:这些值可能来自请求参数、头文件及cookie等。

l         处理验证:当每个组件的本地值被更新后,Lifecycle对象都会验证这些值的合法性

l         更新模型值:负责更新服务器端模型的实际值,通常来讲,这都是通过更新后台Bean(称为管理Bean)的属性实现

l         调用应用程序:JSF控制器调用应用程序来处理应用程序级的事件,就比如执行事件注册的方法

l         呈现响应:此阶段将在视图中显示当前状态的所有组件。

上面的六个阶段都是由内部自动执行,只须对其有初步了解即可。



 

上图:JSF请求处理生命周期的各阶段

概念:

(1)编码、解码、受管bean、监听器、转换器、验证器、导航规则

编码:可以理解成从后台输出到用户页面上的过程;

解码:可以理解成从用户页面请求到服务器端的数据的过程;

(2)静态导航、动态导航

 

 

JSF实现WEB应用:

1、开发、配置受管bean

2、用JSF标记编写JSP页面;

3、在faces-config.xml中配置导航规则;

 

以上知识点是课堂上需要掌握的。接下来根据这些知识点做一题练习题,简单的使用了JSF框架实现两数加减



 

JBuilder中新建WEB站点的时候把图中的JSF勾上,而JSTL1.1自动会勾上,因为JSF要使用到相关的类与标签。

按照步骤可以先建立一个JavaBean或者一个主页面

主页面上放一个链接,下拉调用JSF到一个页面

<a href="add.faces">两个数的运算</a>

 add.faces

 

 

为一个jsp文件,但后缀要改成faces

建立一个JavaBean里面三个属性,两个接收的数字,一个存入相减或相加的和,所以差/和只要一个get方法

接下来要配置该BEAN为受管的BEAN,那么就要动手配置 faces-config.xml 该文件了。

<managed-bean>
     <managed-bean-name>numberbean</managed-bean-name>
     <managed-bean-class>jsfprj1.NumberBean</managed-bean-class>
     <managed-bean-scope>request</managed-bean-scope>
</managed-bean>

<navigation-rule>
      <from-view-id>/add.jsp</from-view-id>
      <navigation-case>
             <from-outcome>ok</from-outcome>
             <to-view-id>/result.jsp</to-view-id>
      <navigation-case>
</navigation-rule>

 

 

 

Managed-bean中的是配置要受管的bean信息

Navigation-rule中就是要配置导航规则

<from-view-id>从哪个页面请求过来的

<from-outcome>点击什么出口(*action

<to-view-id>处理转到哪个页面

建立两个JSP页面add.jsp result.jsp分别都使用 这两个jsf_core html_basic 标签

当从index.jsp连接过来的时候直接跳转到add.jsp页面的时候,实际上JSF已经把页面上的事先写好的生成网页形式在页面上了

下面说说add.jsp中所写的关键代码

<f:view>
    <h:from>
     第一个数:<h:inputText value="#{number.num1}"/><br/>
    第二个数:<h:inputText value="#{number.num2}"/><br/>
    <h:commandButton value="加" action="add" actionListener="#{number.add}"/>
    <h:commandButton value="减" action="dul" actionListener="#{number.dul}"/>
    </h:form>
 </f:view>

 

 

 

这里用到了上面所导入的两个标签;一个是h、另一个是f 

这里要在网页上显示的必须放在<f:view>h 开头的都是与html相关的标签。

上面的是生成一个form表单。Value中的写法比较特殊,是以#{}表示,里面写的内容为javabean别名以及属性名

而在提交表单的时候要注意两个属性值的配置,一个是action是指在faces-config.xml中所配置的导航出处的别名

另一个为actionListener是指配置监听方法,也类似于注册事件,方法不带()

最后在result.jsp页面中显示输出刚才两个数的运算结果,因为导航中配置好点击事件时的出口就是到result.jsp

同样要放在f:view中,使用的标签为<h:outputText>

<f:view>
  <h:outputText value="#{number.num1}"/>
  +
  <h:outputText value="#{number.num2}"/>
 =
<h:outputText value="#{number.sum}"/>

</f:view>

 

 

 

 

 

  • 大小: 25.1 KB
  • 大小: 15 KB
  • 大小: 1.1 KB
   发表时间:2008-10-21  
用JSF做过项目,感觉开发起来有点费劲,特别是UI
0 请登录后投票
   发表时间:2008-10-21  
没用过~
!!!!!
0 请登录后投票
论坛首页 Java企业应用版

跳转论坛:
Global site tag (gtag.js) - Google Analytics