作者marinne (乳瑪琳)
看板Web_Design
標題Re: [問題] 關於樣版化...
時間Thu Mar 10 23:58:47 2005
※ 引述《luoqr ( )》之銘言:
: ※ 引述《luoqr ( )》之銘言:
: : 標題: [問題] 關於樣版化...
: : 時間: Tue Mar 8 16:05:07 2005
: : 請問一下,如果用 JSP 要如何設計樣版化的網頁?
: : 就像 A 網頁只是純 html, B 網頁是 jsp 這樣,
: : 但 A 網頁的資料來自於 B
: : 是要經過一個 parser 的動作嗎?
: : 有沒有更好的作法?
: : 我看到的範例好像都是說 JSP 把資料處理的事情交給後端
: : 但這樣好像還是會在 html 中夾雜 jsp 程式碼 @@
: : 這樣感覺好像不是程式和網頁分開...
: : 有誰能給我點議建嗎?
: : 謝謝...
: : --
: : 有討論這種相關的書嗎
: : --
: : ◆ From: 140.115.221.131
: : 推 i1mare:不知道可不可以call function到網頁,這樣程式網頁 220.135.196.47 03/09
: : → i1mare:就會分離了 220.135.196.47 03/09
: : 推 marinne:你需要的是JSTL,或者更新的玩意兒JSF 220.135.32.37 03/10
: : → marinne:JSTL的話,O'reilly有一本"JavaServer Pages" 220.135.32.37 03/10
: : → marinne:看這本書學,保證.jsp檔案裡面不會出現Java code 220.135.32.37 03/10
: : → marinne:O'reilly也有一本書名就叫做"JavaServer Faces" 220.135.32.37 03/10
: : 推 luoqr:感謝 :D 140.115.156.8 03/10
: 剛看了一下,好像是定義一堆 tag,然後直接在網頁中
: 使用.....
: 但問題來了,如果我今天不喜歡這個版面,我要重新設
: 計一個介面,那這些 tag 不就要再重新嵌入一次?
: 像那些 <c:if test.../> 之類的判斷式不見得會在
: 同一個地方嵌入吧,那等於重新寫一次了不是嗎?
: 有辦法只改 html code,不用動到 jstl 或 jsp code 嗎?
Life is not that easy. Orz
沒錯,使用JSTL,你的.jsp檔案裡面會有一堆<c:if ... />這類標籤,
當你要改版面的時候,得重新更動這些JSTL標籤。但重點在於所有這些
JSTL標籤所代表的邏輯(而且通常都只是簡單的if或者迴圈等)都只和
版面的呈現方式有關,而與資料的結構(資料以何種型式儲存在何種媒介,
以何種方式取得資料等等)或者商業規則(比方說,老闆決定購物金額
未滿500元,則必須收取70元物流處理費)無關,這些東西都放在你的
class裡面,而這些class也不會出現在.jsp檔案裡面。
這就像使用PHP搭配Smarty樣板系統。你的Smarty樣板檔案(.tpl)裡面
會有HTML標籤以及一堆Smarty提供的{if},{elseif},{foreach},{section}
這些標籤,雖然有(簡單的)邏輯在樣板檔案裡面,但是這些邏輯和JSTL
一樣,純粹只和版面的呈現方式有關,而和資料結構與商業邏輯無關。
而你的.php檔案裡面從此就完全不會出現任何HTML了(再細分的話還可能
把資料結構和商業規則寫成class另外儲存,處理要求的.php檔案只是利用
這些class,把資料丟進去,再把回應的資料丟給.tpl去顯示)。
又或者使用code-behind的方式來寫ASP.NET程式,你的.aspx檔案裡面只會
出現HTML以及一堆<asp:DataList... >,<asp:ListBox ...>這些ASP.NET
控制項的設定,而這些HTML和ASP.NET控制項設定也一樣純粹只和版面的
呈現方式有關。你的商業規則和資料存取程式碼在xxx.dll裡面,你的
xxx.aspx.cs則負責接收與驗證資料(這兩者裡面都不會出現任何HTML),
丟給dll提供的class,再把回應的資料交給.aspx去負責顯示在畫面上。
所有這些,在改版面的時候都免不了需要重新編排一些HTML以外的東西。
JSTL的標籤,Smarty的標籤或者ASP.NET控制項的標籤。不過這些code和
Java, PHP, C#(VB.NET)程式碼相較之下都遠遠簡單得多,而且都僅限於
一些簡單的邏輯判斷,比起將HTML與程式碼混合在一起的做法,修改起來
要容易太多了。
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 220.135.32.37
1F:推 luoqr:謝謝你的回應 給我很大收獲 :) 140.115.156.8 03/11