一、快速搭建 Velocity 框架

1. 加入所需 Jar 包

<dependency>
<groupId>org.apache.velocity</groupId>
<artifactId>velocity</artifactId>
<version>1.7</version>
</dependency>
<dependency>
<groupId>velocity-tools</groupId>
<artifactId>velocity-tools-generic</artifactId>
<version>2.0-beta1</version>
</dependency>
<dependency>
<groupId>velocity-tools</groupId>
<artifactId>velocity-tools-view</artifactId>
<version>2.0-beta1</version>
</dependency>
<dependency>
<groupId>commons-digester</groupId>
<artifactId>commons-digester</artifactId>
<version>2.1</version>
</dependency>

2. 修改 SpringMVC 的配置文件 springmvc-servlet.xml

旧配置:

<!-- 对加载页面的路径解析 -->
<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
  <!-- 前缀 -->
  <property name="prefix" value="/"></property>
  <!-- 后缀 -->
  <property name="suffix" value=".html"></property>
</bean>

改为:

<!-- 对加载页面的路径解析 不需要配 prefix, 在 velocity-servlet.xml 中配置 -->
<bean id="viewResolver" class="org.springframework.web.servlet.view.velocity.VelocityViewResolver">
  <!-- 加载 toolbox 配置文件 -->
  <property name="toolboxConfigLocation" value="/WEB-INF/velocityToolBox.xml" />
  <!-- 后缀 -->
  <property name="suffix" value=".vm"></property>
</bean>

3. 在 WEB-INF 下面创建配置文件,命名为 velocityToolBox.xml

<toolbox>
  <!-- application start -->
  <tool>
    <key>date</key>
<scope>application</scope>
<class>org.apache.velocity.tools.generic.DateTool</class>
  </tool>
  <tool>
<key>math</key>
<scope>application</scope>
    <class>org.apache.velocity.tools.generic.MathTool</class>
  </tool>
  <!-- application end -->
</toolbox>

4. 在 WEB-INF 下创建配置文件 velocity-servlet.xml

<bean id="velocityConfigurer"
class="org.springframework.web.servlet.view.velocity.VelocityConfigurer">
  <!-- 模版路径 -->
  <property name="resourceLoaderPath">
    <!-- prefix -->
    <value>/</value>
  </property>
  <!-- 模版属性 -->
  <property name="velocityProperties">
    <props>
      <prop key="input.encoding">utf-8</prop>
      <prop key="output.encoding">utf-8</prop>
    </props>
  </property>
</bean>

记得在 web.xml 文件中引入 velocity-servlet.xml

5. velocity 模板的一些基本指令

比如循环:后台传递过来的用户信息列表 userList

#foreach($item in $userList)
<div>$item.userName $item.createDate</div>
#end

二. 如何自定义标签

1. 先创建一个自定义标签 Java 类。必须要有 @DefaultKey("") 注解

package com.erim.web.common;

@DefaultKey("erim")
public class ErimTag {
  // 格式化时间
public String formatDate(Date date) {
return new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(date);
}
}

2. 修改 WEB-INF 下 velocityToolBox.xml 引入 Java 类

<tool>
<key>erim</key>
<scope>application</scope>
<class>com.erim.web.common.ErimTag</class>
</tool>

这样自定义注解就生效了。假如后台有一个时间变量 createDate 需要在页面渲染,渲染完发现格式是酱紫的:

Thu May 12 15:20:02 CST 2016

这就需要用到我们的自定义标签:

$erim.formatDate($createDate)

三. 如何自定义指令

1. 还是先创建一个 Java 类,继承 Directive。

public class TextTag extends Directive {

    @Override
public String getName() {
return "vText";
} @Override
public int getType() {
return LINE;
} @Override
public boolean render(InternalContextAdapter context, Writer writer, Node node)
throws IOException, ResourceNotFoundException, ParseErrorException,
MethodInvocationException {
// 获取第一个参数
SimpleNode user = (SimpleNode) node.jjtGetChild(0);
// 格式化
String userName = (String) user.value(context);
// 操作
userName = userName + ".....";
// 输出
writer.write(userName);
return true;
} }

2. 在 WEB-INF 下创建资源文件 velocity.properties

input.encoding=utf-8
output.encoding=utf-8
userdirective=com.erim.web.common.TextTag

其中 userdirective 的值为自定义指令 Java 类的地址,多个 Java 类以逗号分隔

3. 修改 velocity-servlet.xml 文件

<!-- velocity 相关配置 -->
<bean id="velocityConfigurer"
  class="org.springframework.web.servlet.view.velocity.VelocityConfigurer">
  <!-- 引入外部资源 -->
  <property name="configLocation" value="/WEB-INF/velocity.properties" />
  <!-- 模板路径 -->
  <property name="resourceLoaderPath" value="/templates/"></property>
  <!-- 模板属性 -->
  <property name="velocityProperties">
    <props>
      <prop key="input.encoding">utf-8</prop>
      <prop key="output.encoding">utf-8</prop>
    </props>
  </property>
</bean>

4. 使用场景

#vText("hhahaha")

hahahha, demo 就是这么任意

#vText 就是上面 getName() 方法中指定的字符串。

SpringMVC 学习-如何搭配使用 Velocity 页面模板的更多相关文章

  1. SpringMvc学习心得(五)控制器产生与构建

    SpringMvc学习心得(五)控制器产生与构建 标签: springspring mvc框架 2016-03-22 15:29 140人阅读 评论(0) 收藏 举报  分类: Spring(4)  ...

  2. SpringMVC学习系列-后记 解决GET请求时中文乱码的问题

    SpringMVC学习系列-后记 解决GET请求时中文乱码的问题 之前项目中的web.xml中的编码设置: <filter> <filter-name>CharacterEnc ...

  3. 史上最全的SpringMVC学习笔记

    SpringMVC学习笔记---- 一.SpringMVC基础入门,创建一个HelloWorld程序 1.首先,导入SpringMVC需要的jar包. 2.添加Web.xml配置文件中关于Spring ...

  4. SpringMVC学习系列-后记 开启项目的OpenSessionInView

    在系列的 SpringMVC学习系列(12) 完结篇 的示例项目中,由于当时考虑到OpenSessionInView会对性能有一定的影响,所以就没有配置项目的OpenSessionInView.在ma ...

  5. SpringMVC学习系列-后记 结合SpringMVC和Hibernate-validator,根据后台验证规则自动生成前台的js验证代码

    在SpringMVC学习系列(6) 之 数据验证中我们已经学习了如何结合Hibernate-validator进行后台的数据合法性验证,但是通常来说后台验证只是第二道保险,为了更好的用户体验会现在前端 ...

  6. springmvc学习笔记--REST API的异常处理

    前言: 最近使用springmvc写了不少rest api, 觉得真是一个好框架. 之前描述的几篇关于rest api的文章, 其实还是不够完善. 比如当遇到参数缺失, 类型不匹配的情况时, 直接抛出 ...

  7. springmvc学习笔记---面向移动端支持REST API

    前言: springmvc对注解的支持非常灵活和飘逸, 也得web编程少了以往很大一坨配置项. 另一方面移动互联网的到来, 使得REST API变得流行, 甚至成为主流. 因此我们来关注下spring ...

  8. SpringMVC:学习笔记(8)——文件上传

    SpringMVC--文件上传 说明: 文件上传的途径 文件上传主要有两种方式: 1.使用Apache Commons FileUpload元件. 2.利用Servlet3.0及其更高版本的内置支持. ...

  9. springmvc学习笔记(简介及使用)

    springmvc学习笔记(简介及使用) 工作之余, 回顾了一下springmvc的相关内容, 这次也为后面复习什么的做个标记, 也希望能与大家交流学习, 通过回帖留言等方式表达自己的观点或学习心得. ...

随机推荐

  1. C# 去除文件和文件夹的只读属性

    当我们使用 DirectoryInfo dir = Directory.CreateDirectory(pathName) 创建目录或者创建一个文件后,有时作为临时文件用完以后需要删除掉,使用File ...

  2. angular.js升序降序过滤器

    向指令添加过滤器 过滤器可以通过一个管道字符(|)和一个过滤器添加到指令中. orderBy 过滤器根据表达式排列数组: 例如: <div ng-app="myApp" ng ...

  3. 【cocos2d-js 3.0】制作2048

    2048:在一个4X4的方阵中,玩家需要滑动上面的数字,如果俩个数字相邻并且相等,则相加,需要达到2048,方可胜利. 因为在浏览器操作,所以此例的操作方法为:键盘上的w,s,a,d代表上下左右,也可 ...

  4. A*寻路算法 (cocos2d-js详细代码)

    看了几天的A*算法,感觉要成为一个游戏开发者,有必要把这个著名的算法拿到手. 网上有此算法的代码片段,但主要还是些模板类的伪代码,所以想分享一段完整的A*算法代码供大家更好的理解!(这里使用的是js语 ...

  5. CodeForces 696C PLEASE

    快速幂,费马小定理,逆元. 设$dp[n]$表示$n$次操作之后的概率,那么$dp[n] = \frac{{(1 - dp[n - 1])}}{2}$.$1-dp[n - 1]$表示上一次没有在中间的 ...

  6. The most orzed and orzing man

    The most orzed and orzing man 题目链接:http://acm.xidian.edu.cn/problem.php?id=1184 Sprague-Grundy定理:htt ...

  7. ajax 跨域携带COOKIE

    这个问题属于Ajax跨域携带Cookie的问题,找了一篇博文的解决方案. 原生ajax请求方式: var xhr = new XMLHttpRequest(); xhr.open("POST ...

  8. Swift逃逸闭包之见解

    Swift 逃匿闭包顾名思义,就是闭包想要逃跑.当闭包作为参数传给一个方法时,在这个方法被调用完后闭包却还没有被执行,而是等到方法执行完后才调用 基本都是跨线程的时候才会有逃逸闭包这个说法.因为异步 ...

  9. STS中Maven配置

    最近接触maven, 配置过程中记录一下. STS是解压版的,启动后,可以看到已经有了Maven插件, , 但是,STS也同时给你了一个Maven,但是通常不建议使用STS自带的maven.使用默认的 ...

  10. 整体认识flume:Flume介绍、分布式安装、常见问题及解决方案

    问题导读 1.什么是flume? 2.flume包含哪些组件? 3.Flume在读取utf-8格式的文件时会出现解析不了时间戳,该如何解决? Flume是一个分布式.可靠.和高可用的海量日志采集.聚合 ...