程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> JAVA編程入門知識 >> java Tapestry4.1.2入門說明教程

java Tapestry4.1.2入門說明教程

編輯:JAVA編程入門知識
簡單介紹
不必關心鏈接!不必關心請求(http request)到了哪裡!不必關心響應(http response)要轉向哪裡!Tapestry構建於底層的request-resonse模式,基於Servlet技術,抽象出面向組件開發的模型。Tapestry關心的是:頁面、組件、事件、對象、方法、屬性!
安裝jar包
1、
將Tapestry解壓目錄下的lib目錄中的jar包拷貝到WEB-INF/lib目錄。
並將重復的包刪除(commons-logging.jar/javassist.jar/ognl-2.6.11.jar)
2、
在web.xml中添加:
代碼如下:

<servlet>
<servlet-name>app</servlet-name>
<servlet-class>org.apache.tapestry.ApplicationServlet</servlet-class>
<load-on-startup>0</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>app</servlet-name>
<url-pattern>/app</url-pattern>
</servlet-mapping>

這是Tapestry的中央控制器。Tapestry頁面的顯示,所有的請求,都會被發送到這個Servlet上。
實例1:最簡單的Tapestry程序
在WebRoot下添加Home.html 
代碼如下:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=GB18030">
<title>Insert title here</title>
</head>
<body>
第一個Tapestry程序
</body>
</html>

並訪問網址:
http://localhost:8088/[context path]/app
結果頁面顯示Home.html裡面的內容。
這是因為Tapestry總是會包含一個名字叫”Home”的頁面,默認情況下就是根路徑下的Home.html
實例2:添加簡單的動態內容
Home.html改為: 
代碼如下:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=GB18030">
<title>Insert title here</title>
</head>
<body>
第一個Tapestry程序
現在時間是:<span jwcid="@Insert" value="ognl:new java.util.Date()"> </span>
</body>
</html>

重新訪問網址:http://localhost:8088/[context path]/app
在這個頁面上,用到了Tapestry的Insert組件(Component)。它帶一個參數,通過一個ognl表達式來傳遞。
在應用服務器的啟動參數中添加:-Dorg.apache.tapestry.disable-caching=true,可以避免每次修改頁面模板的時候重啟服務器。
jwc = Java Web Component
實例3:創建鏈接,指向某個頁面
代碼如下:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=GB18030">
<title>Insert title here</title>
</head>
<body>
第一個Tapestry程序
現在時間是:<span jwcid="@Insert" value="ognl:new java.util.Date()"></span>
<p>
<a href="#" jwcid="@PageLink" page="Home">刷新</a>
</body>
</html>

這次,通過一個PageLink組件,指向Home頁面,PageLink組件會自動產生指向Home頁面的鏈接(我們不必關心這個鏈接!)。
實例4:簡單的計數器
直到現在為止,我們還沒有涉及到java類,但是已經讓Tapestry成功運行起來了!該是寫點java代碼的時候了。我們想要創建一個計數器,每當用戶點擊“計數器增1”的時候,我們將這個計數器加1,然後在頁面上顯示出這個結果。
在傳統的請求-響應模式中,我們針對這個問題,需要考慮的是:遞交一個請求,創建相應的Action來接收這個請求,並維護計數器的值,然後決定成功轉向的頁面,將結果顯示在頁面上。
在Tapestry中,我們需要考慮的是:在哪個頁面處理這個事件,結果如何顯示在頁面上?
下面是Home.html
代碼如下:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=GB18030">
<title>Insert title here</title>
</head>
<body>
第一個Tapestry程序
現在時間是:<span jwcid="@Insert" value="ognl:new java.util.Date()"></span>
<p>
<a href="#" jwcid="@PageLink" page="Home">刷新</a>
<p>
計數器當前的值是:<span jwcid="@Insert" value="ognl:counter"></span>
<a href="#" jwcid="@DirectLink" listener="listener:doClick">計數器增1</a>
</body>
</html>

DirectLink指定的listener為:doClick,這將觸發一個事件,實際上就是將要調用doClick()方法。
doClick()方法將要寫在哪裡?因為現在的頁面,其動態數據無法簡單獲得,所以,必須給當前頁面創建一個對應的類,我們的方法將創建在這個類裡面。
代碼如下:

package com.bjsxt.crm.web.tapestry.test;
import org.apache.tapestry.annotations.Persist;
import org.apache.tapestry.html.BasePage;
public abstract class Home extends BasePage {
@Persist
public abstract int getCounter();
public abstract void setCounter(int count);
public void doClick(){
int counter = getCounter();
counter = counter + 1;
setCounter(counter);
}
}

注意:在這個例子中,類名需定義為Home;listener的名字為doClick,而不是doClick()
另外,需要在web-inf目錄下添加配置文件:app.application 
代碼如下:

<?xml version="1.0"?>
<!DOCTYPE application PUBLIC
"-//Apache Software Foundation//Tapestry Specification 4.0//EN"
"http://tapestry.apache.org/dtd/Tapestry_4_0.dtd">
<application>
<meta key="org.apache.tapestry.page-class-packages" value="com.bjsxt.crm.web.tapestry.test"/>
</application>

配置的主要目的是讓Tapestry了解如何關聯頁面和頁面類。
實例5:帶一個參數的計數器
Home.html改為: 
代碼如下:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=GB18030">
<title>Insert title here</title>
</head>
<body>
第一個Tapestry程序
現在時間是:<span jwcid="@Insert" value="ognl:new java.util.Date()"></span>
<p>
<a href="#" jwcid="@PageLink" page="Home">刷新</a>
<p>
計數器當前的值是:<span jwcid="@Insert" value="ognl:counter"></span>
<a href="#" jwcid="@DirectLink" listener="listener:doClick" parameters="ognl:1">計數器增1</a> <br>
<a href="#" jwcid="@DirectLink" listener="listener:doClick" parameters="ognl:5">計數器增5</a> <br>
<a href="#" jwcid="@DirectLink" listener="listener:doClick" parameters="ognl:10">計數器增10</a> <br>
<a href="#" jwcid="@DirectLink" listener="listener:clearCounter">清空計數器</a>
</body>
</html>

  • 首頁
  • 上一頁
  • 1
  • 2
  • 下一頁
  • 尾頁
  • 共2頁
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved