Velocity模板和Spring的整合配置

Velocity是什么?

Velocity是一種基于java的模板引擎技術(shù),有點(diǎn)類似與JSP,它允許頁面設(shè)計(jì)者引用Java中定義的方法。前端頁面設(shè)計(jì)者和后端Java開發(fā)者能夠同時(shí)使用MVC的模式開發(fā)網(wǎng)站,這樣前端能夠把精力放在頁面的設(shè)計(jì)上,后端也可以把精力放在代碼開發(fā)上。Velocity把Java代碼從Web頁面中分離, 使網(wǎng)站可維護(hù)性更強(qiáng).

項(xiàng)目中如何引入, 從一個(gè)簡單demo開始

maven添加如下依賴

<dependency>
    <groupId>org.apache.velocity</groupId>
    <artifactId>velocity</artifactId>
    <version>1.7</version>
</dependency>
<dependency>  
    <groupId>org.apache.velocity</groupId>  
    <artifactId>velocity-tools</artifactId>  
    <version>2.0</version>  
</dependency>  

配置spring的視圖解析配置 -- Velocity視圖解析器, 最簡單的配置

Spring的配置文件在哪?
在項(xiàng)目web.xml中的<servlet>配置中, 找到DispatcherServlet的配置,
contextConfigLocation的屬性的value.

<!-- 一.配置試圖解析器--> 
<bean id="viewResolver" class="org.springframework.web.servlet.view.velocity.VelocityViewResolver"> 
    <!-- 1.前綴, 后綴 , 后綴是決定你模板的后綴的, 可以是其他例如.vm, 如果你喜歡的話 -- >
    <property name="prefix" value=""/> 
    <property name="suffix" value=".html"/> 
    <!-- 2.為解決頁面亂碼問題, 必須配置 -->
    <property name="contentType" value="text/html;charset=utf-8"/> 
    <!-- 3.toolbox配置文件路徑, 非必須-->  
    <property name="toolboxConfigLocation" value="/WEB-INF/toolbox.xml"/> 
</bean>
<!-- 二.配置velocity模板路徑, 配置文件路徑等 -->
<bean id="velocityConfig" class="org.springframework.web.servlet.view.velocity.VelocityConfigurer"> 
    <!-- 1.模板位置路徑 -->
    <property name="resourceLoaderPath" value="/WEB-INF/velocity/templates"/> 
    <!-- 2.配置文件路徑 -->
   <property name="configLocation" value="classpath:velocity/velocity.properties"/>   
</bean>
關(guān)于toolboxConfigLocation

這個(gè)toolbox.xml 配置文件 就是配置java后臺(tái)寫的工具類, 拿到頁面上直接用.類似于jsp技術(shù)中的include某個(gè)工具類的用法.

<?xml version="1.0" encoding="UTF-8" ?>
    <toolbox> 
        <tool> 
            <key>StringUtil</key> 
            <class>com.xxx.util.StringUtil</class>
            <scope>application</scope> 
        </tool> 
    </toolbox>

配置velocity.properties 最簡單的配置

其實(shí)最簡單的配置就是把編碼設(shè)置上. 此處不配置編碼, 頁面會(huì)亂碼. 同時(shí)如果少了上面的contentType配置, 同樣亂碼

input.encoding  =UTF-8
output.encoding = UTF-8

HelloVelocity的模板文件

在上述的配置文件中resourceLoaderPath的路徑下建立模板文件

<!DOCTYPE html>
<html> 
<title>Hello Velocity模板文件</title> 
<body> 
    <h1>Hello $name !</h1>
    <h2>當(dāng)前時(shí)間 : $date !</h2>
</body>
</html>

$name$date 是velocity的語法, 類似于el 的 ${name} ${date}, 所以下一步上后臺(tái)給這兩個(gè)key賦值

后臺(tái)Controller代碼

@Controller
@RequestMapping("/velocity")
public class VelocityController {

    @RequestMapping(value="/test")
    public String test(Model model) {  
        String name = "安仔";  
        model.addAttribute("name", name); 
        model.addAttribute("date", new Date());
        return "velocity";  
    }  
    
}

最終頁面呈現(xiàn)類似于jsp, 但效率高于jsp

模板頁面

參考資料

Velocity詳細(xì)配置講解
官方文檔翻譯

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,362評(píng)論 6 537
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,013評(píng)論 3 423
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,346評(píng)論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,421評(píng)論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,146評(píng)論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,534評(píng)論 1 325
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,585評(píng)論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,767評(píng)論 0 289
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,318評(píng)論 1 335
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,074評(píng)論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,258評(píng)論 1 371
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,828評(píng)論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,486評(píng)論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,916評(píng)論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,156評(píng)論 1 290
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 51,993評(píng)論 3 395
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,234評(píng)論 2 375

推薦閱讀更多精彩內(nèi)容

  • Spring Boot 參考指南 介紹 轉(zhuǎn)載自:https://www.gitbook.com/book/qbgb...
    毛宇鵬閱讀 46,900評(píng)論 6 342
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 134,807評(píng)論 18 139
  • Beetl2.7.16中文文檔 Beetl作者:李家智 <xiandafu@126.com> 1. 什么是Beet...
    西漠閱讀 2,724評(píng)論 0 0
  • 知周從小是個(gè)犟丫頭,好像從來就學(xué)不會(huì)低頭。在她眼里的世界,似乎不是黑就是白。 犯了錯(cuò),媽媽打斷衣架也聽不到她服軟,...
    傻得都方了閱讀 838評(píng)論 4 15
  • 蘇沐原創(chuàng),轉(zhuǎn)載請(qǐng)聯(lián)系授權(quán)。 暗沉的夜過去了,縹緲無際的天空終又泛起灰白蒼茫的光亮來。萬物以永不失諾的姿態(tài)循環(huán)往復(fù)著...
    蘇沐執(zhí)筆閱讀 1,880評(píng)論 0 2