T5学习小结之四(Form的基本应用2)

同样是简单的login流程,下面展示如何进行page navigation和使用带t:value的input框:

Start.html(为了显示中文,使用了Messages进行localization):
html 代码
 
  1. <html xmlns:t="http://tapestry.apache.org/schema/tapestry_5_0_0.xsd">  
  2. <head>  
  3. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>  
  4. <title>hilo - ${message:page-title}<!---->title>  
  5. <!---->head>  
  6. <body>  
  7. <div align="center"><h3>${message:body-title}<!---->h3><!---->div>  
  8. <div align="center">  
  9. <form t:type="Form">  
  10. <table cellpadding="3">  
  11. <tr><td colspan="2" align="center" bgcolor="CC00AA">${message:body-title}<!---->td><!---->tr>  
  12. <tr><td>${message:name-label}<!---->td><td><input t:type="TextField" t:id="userName" t:value="user.name" type="text"/><!---->td><!---->tr>  
  13. <tr><td>${message:pass-label}<!---->td><td><input t:type="PasswordField" t:id="passWord" t:value="user.pass" type="password"/><!---->td><!---->tr>  
  14. <tr><td colspan="2" align="center"><input type="submit" value="Login"/> <input type="reset" value="Reset"/><!---->td><!---->tr>  
  15. <!---->table>  
  16. <!---->form>  
  17. <!---->div>  
  18. <!---->body>  
  19. <!---->html>  

Start.java:
java 代码
 
  1. package org.examples.pages;  
  2.   
  3. import org.apache.tapestry.annotations.InjectPage;  
  4. import org.examples.data.User;  
  5.   
  6. public class Start {  
  7.       
  8.     private User _user;  
  9.       
  10.     @InjectPage  
  11.     private Test _test;  
  12.       
  13.     void onPrepare(){  
  14.         if(_user == null)  
  15.             _user = new User();  
  16.     }  
  17.       
  18.     String onSuccess(){  
  19.         _test.setUser(_user);  
  20.         System.out.println("当前登录的用户是:"+getUser().getName());  
  21.         return "test";  
  22.     }  
  23.     public User getUser() {  
  24.         return _user;  
  25.     }  
  26.     public void setUser(User user) {  
  27.         _user = user;  
  28.     }  
  29. }  


Start.properties:

代码:
  1. page-title=登录页面  
  2. body-title=用户登录  
  3. name-label=用户名:  
  4. pass-label=密  码:  

User.java:
java 代码
 
  1. package org.examples.data;  
  2.   
  3. public class User {  
  4.   
  5.     private String _name;  
  6.     private String _pass;  
  7.       
  8.     public String getName() {  
  9.         return _name;  
  10.     }  
  11.     public String getPass() {  
  12.         return _pass;  
  13.     }  
  14.     public void setName(String name) {  
  15.         _name = name;  
  16.     }  
  17.     public void setPass(String pass) {  
  18.         _pass = pass;  
  19.     }  
  20.       
  21. }  

Test.html:
xml 代码
 
  1. <html xmlns:t="http://tapestry.apache.org/schema/tapestry_5_0_0.xsd">  
  2. <head>  
  3. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>  
  4. <title>hilo Login here<!---->title>  
  5. <!---->head>  
  6. <body>  
  7. Welcome, ${user.name}!  
  8. <!---->body>  
  9. <!---->html>  

Test.java:
java 代码
 
  1. package org.examples.pages;  
  2.   
  3. import org.apache.tapestry.annotations.Persist;  
  4. import org.examples.data.User;  
  5.   
  6. public class Test {  
  7.     @Persist  
  8.     private User _user;  
  9.           
  10.     String onActivate(){  
  11.         if(_user==null || _user.getName()=="")  
  12.             return "start";  
  13.         else return null;  
  14.           
  15.     }  
  16.   
  17.     public void setUser(User user) {  
  18.         _user = user;  
  19.     }  
  20.   
  21.     public User getUser() {  
  22.         return _user;  
  23.     }  
  24. }  

小结:
1. 要使用onActivate()方法进行Page Navigation(页面导航),尤其是页面保护;
2. 使用形如
 
  1. <input t:type="textfield" t:id="name" t:value="user.name"/>  
模板时,必须对user对象进行初始化,不然页面将不能正常运行(抛出异常)。对象的初始化使用onPrepare()方法。
3. 一般的登录/创建/更新页面可以使用BeanEditForm,则更为方便快捷,其模板为:
<t:comp type="beaneditform" object="user" submitlabel="Login">
 
  1. <t:comp type="beaneditform" object="user" submitLabel="Login"/>  

在页面类中只要简单地建立user对象的getter和setter就行,不再需要onPrepare()对user对象进行初始化了。</t:comp>

你可能感兴趣的:(apache,html,xml,tapestry)