使用Velocity?模板引擎開(kāi)發(fā)網(wǎng)站
Velocity?是如何工作的呢??雖然大多?Velocity?的應(yīng)用都是基于?Servlet?的網(wǎng)頁(yè)制作。但是為了說(shuō)明?Velocity?的使用,我決定采用更通用的?Java?application?來(lái)說(shuō)明它的工作原理。?
似乎所有語(yǔ)言教學(xué)的開(kāi)頭都是采用?HelloWorld?來(lái)作為第一個(gè)程序的示例。這里也不例外。?
任何?Velocity?的應(yīng)用都包括兩個(gè)方面:
第一是:?模板制作,在我們這個(gè)例子中就是?hellosite.vm:
它的內(nèi)容如下(雖然不是以?HTML?為主,但是這很容易改成一個(gè)?html?的頁(yè)面)
Hello?$name!?Welcome?to?$site?world!
第二是?Java?程序部分:
下面是?Java?代碼
import?org.apache.velocity.app.VelocityEngine;
import?org.apache.velocity.Template;
import?org.apache.velocity.VelocityContext;
public?class?HelloWorld{
????public?static?void?main(?String[]?args?)throws?Exception{
????????/*?first,?get?and?initialize?an?engine?*/
????????VelocityEngine?ve?=?new?VelocityEngine();
????????ve.init();
????????/*?next,?get?the?Template?*/
????????Template?t?=?ve.getTemplate(?"hellosite.vm"?);
????????/*?create?a?context?and& nbsp;add?data?*/
????????VelocityContext?context?=?new?VelocityContext();
????????context.put("name",?"Eiffel?Qiu");
????????context.put("site",?" http://www.eiffelqiu.com ");
????????/*?now?render?the?template?into?a?StringWriter?*/
????????StringWriter?writer?=?new?StringWriter();
????????t.merge(?context,?writer?);
????????/*?show?the?World?*/
????????System.out.println(?writer.toString()?);?
????}
}
將兩個(gè)文件放在同一個(gè)目錄下,編譯運(yùn)行,結(jié)果是:?
Hello?Eiffel?Qiu!?Welcome?to?
http://www.eiffelqiu.com
?world?
為了保證運(yùn)行順利,請(qǐng)從?Velocity?的網(wǎng)站?
http://jakarta.apache.org/velocity/
?上下載?Velocity?的運(yùn)行包,將其中的?Velocity?Jar?包的路徑放在系統(tǒng)的?Classpath?中,這樣就可以編譯和運(yùn)行以上的程序了。
這個(gè)程序很簡(jiǎn)單,但是它能讓你清楚的了解?Velocity?的基本工作原理。程序中其他部分基本上很固定,最主要的部分在以下代碼?
這里?Velocity?獲取模板文件,得到模板引用
Template?t?=?ve.getTemplate(?"hellosite.vm"?);
這里,初始化環(huán)境,并將數(shù)據(jù)放入環(huán)境
VelocityContext?context?=?new?VelocityContext();
context.put("name",?"Eiffel?Qiu");
context.put("site",?" http://www.eiffelqiu.com ");
其他代碼比較固定,但是也非常重要,但是對(duì)于每個(gè)應(yīng)用來(lái)說(shuō)寫(xiě)法都很相同:
這是初始化?Velocity?模板引擎
VelocityEngine?ve?=?new?VelocityEngine();
ve.init();
這是用來(lái)將環(huán)境變量和輸出部分結(jié)合。
t.merge(?context,?writer?);
/*?show?the?World?*/
System.out.println(?writer.toString()?);?
記住,這在將來(lái)的?servlet?應(yīng)用中會(huì)有所區(qū)別,因?yàn)榫W(wǎng)頁(yè)輸出并不和命令行輸出相同,如果用于網(wǎng)頁(yè)輸出,將并不通過(guò)?System.out?輸出。這會(huì)在以后的教程中給大家解釋的。?
那讓我來(lái)總結(jié)一下?Velocity?真正的工作原理:?
Velocity?解決了如何在?Servlet?和?網(wǎng)頁(yè)之間傳遞數(shù)據(jù)的問(wèn)題,當(dāng)然這種傳輸數(shù)據(jù)的機(jī)制是在?MVC?模式上進(jìn)行的,也就是 View?和?Modle?,?Controller?之間相互獨(dú)立工作,一方的修改不影響其他方變動(dòng),他們之間是通過(guò)環(huán)境變量(Context)來(lái)實(shí)現(xiàn) 的,當(dāng)然雙方網(wǎng)頁(yè)制作一方和后臺(tái)程序一方要相互約定好對(duì)所傳遞變量的命名約定,比如上個(gè)程序例子中的?site,?name?變量,它們?cè)诰W(wǎng)頁(yè)上就 是?$name?,$site?。?這樣只要雙方約定好了變量名字? 敲此驕涂梢遠(yuǎn)懶⒐ぷ髁恕?nbsp;無(wú)論頁(yè)面如何變化,只要變量名不變,那么后臺(tái)程序就無(wú)需改動(dòng),前臺(tái)網(wǎng)頁(yè)也可以任意由網(wǎng)頁(yè)制作人員修改。這就 是?Velocity?的工作原理。?
你會(huì)發(fā)現(xiàn)簡(jiǎn)單變量名通常無(wú)法滿足網(wǎng)頁(yè)制作顯示數(shù)據(jù)的需要,比如我們經(jīng)常會(huì)循環(huán)顯示一些數(shù)據(jù)集, 或者是根據(jù)一些數(shù)據(jù)的值來(lái)決定如何顯示下一步的數(shù)據(jù),?Velocity?同樣提供了循環(huán),判斷的簡(jiǎn)單語(yǔ)法以滿足網(wǎng)頁(yè)制作的需要。Velocity?提供 了一個(gè)簡(jiǎn)單的模板語(yǔ)言以供前端網(wǎng)頁(yè)制作人員使用,這個(gè)模板語(yǔ)言足夠簡(jiǎn)單(大部分懂得?javascript?的人就可以很快掌握,其實(shí)它 比?javascript?要簡(jiǎn)單的多),當(dāng)然這種簡(jiǎn)單是刻意的,因?yàn)樗恍枰裁炊寄茏觯?View?層其實(shí)不應(yīng)該包含更多的邏 輯,Velocity?的簡(jiǎn)單模板語(yǔ)法可以滿足你所有對(duì)頁(yè)面顯示邏輯的需要,這通常已經(jīng)足夠了,這里不會(huì)發(fā)生象?jsp?那樣因?yàn)橐粋€(gè)無(wú)限循環(huán)語(yǔ)句而毀掉 系統(tǒng)的情況,jsp?能做很多事情,Sun?在制定?Jsp?1.0?標(biāo)準(zhǔn)的時(shí)候,沒(méi)有及時(shí)的限定程序員在?jsp?插入代碼邏輯,使得早期的jsp?代 碼更象是?php&nb sp;代碼,它雖然強(qiáng)大,但是對(duì)顯示層邏輯來(lái)說(shuō),并不必要,而且會(huì)使?MVC?三層的邏輯結(jié)構(gòu)發(fā)生混淆。
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
