JSF入门笔记

首先简单的理解一下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>

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值