锁定老帖子 主题: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>
声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2008-10-21
用JSF做过项目,感觉开发起来有点费劲,特别是UI
|
|
返回顶楼 | |
发表时间:2008-10-21
没用过~
!!!!! |
|
返回顶楼 | |
浏览 4963 次