第三章 【若依框架:Velocity】Velocity模板引擎深度应用

目录

一、Velocity基础概念

二、Velocity快速入门

[1. 基础模板示例](#1. 基础模板示例)

[2. Java代码渲染](#2. Java代码渲染)

三、Velocity核心语法

[1. 变量定义与使用](#1. 变量定义与使用)

[2. 对象操作](#2. 对象操作)

[3. 循环控制](#3. 循环控制)

[4. 条件判断](#4. 条件判断)

四、代码生成模板实战

[1. 实体类模板改造(集成Lombok)](#1. 实体类模板改造(集成Lombok))

[2. Controller模板改造(集成Swagger)](#2. Controller模板改造(集成Swagger))


本文介绍了Java模板引擎Velocity的基础概念和核心语法。Velocity可实现界面与代码分离,常用于Web内容生成、代码生成、SQL脚本等场景。文章首先展示了基础模板示例和Java渲染代码,然后详细讲解了变量定义、对象操作、循环控制和条件判断等核心语法。最后通过实体类模板和Controller模板的实战案例,展示了如何集成Lombok和Swagger进行代码生成。全文涵盖了Velocity从基础到应用的关键知识点,为开发者提供了实用的技术参考。

一、Velocity基础概念

Velocity是基于Java的模板引擎,实现界面与代码分离,主要应用场景:

  • Web内容动态生成

  • Java源代码生成

  • SQL脚本生成

  • XML配置文件生成

  • 网页静态化

二、Velocity快速入门

1. 基础模板示例
html 复制代码
<!DOCTYPE html>
<html>
<body>
    <h3>动态内容:${message}</h3>
</body>
</html>
2. Java代码渲染
java 复制代码
public class VelocityDemo {
    public static void main(String[] args) throws Exception {
        // 初始化模板引擎
        VelocityInitializer.initVelocity();
        
        // 准备数据模型
        VelocityContext context = new VelocityContext();
        context.put("message", "动态内容示例");
        
        // 读取并渲染模板
        Template template = Velocity.getTemplate("vm/template.html.vm", "UTF-8");
        FileWriter writer = new FileWriter("output.html");
        template.merge(context, writer);
        writer.close();
    }
}

三、Velocity核心语法

1. 变量定义与使用
java 复制代码
velocity

## 定义变量
#set($name = "velocity")

## 使用变量
变量值:${name}
简写形式:$name

## 字符串拼接
#set($service = "order")
${service}Service  ## 输出:orderService
2. 对象操作
java 复制代码
velocity

## 对象属性访问
区域ID:$region.id
区域名称:${region.regionName}
3. 循环控制
java 复制代码
velocity

## 集合遍历
#set($seasons = ["春", "夏", "秋", "冬"])
#foreach($item in $seasons)
   序号[$foreach.count] $item
#end

## 对象集合遍历
#foreach($region in $regionList)
   区域ID:$region.id,名称:$region.regionName
#end
4. 条件判断
java 复制代码
velocity

## if-else判断
#set($score = 85)
#if($score >= 80)
    优秀
#elseif($score >= 60)
    及格
#else
    不及格
#end

## 对象空值判断
#if($obj)
   对象存在
#end

#if(!$obj)
   对象为空
#end

四、代码生成模板实战

1. 实体类模板改造(集成Lombok)
java 复制代码
velocity

package ${packageName}.domain;

#foreach ($import in $importList)
import ${import};
#end
import com.example.common.annotation.Excel;
import com.example.common.core.domain.BaseEntity;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;

/**
 * ${functionName}对象 ${tableName}
 */
@Data
@NoArgsConstructor
@AllArgsConstructor
@Builder
public class ${ClassName} extends BaseEntity {
    private static final long serialVersionUID = 1L;
    
    #foreach ($column in $columns)
    #if(!$table.isSuperColumn($column.javaField))
    /** $column.columnComment */
    #if($column.list)
    @Excel(name = "${column.columnComment}")
    #end
    private $column.javaType $column.javaField;
    #end
    #end
    
    #if($table.sub)
    private List<${subClassName}> ${subclassName}List;
    #end
}
2. Controller模板改造(集成Swagger)
java 复制代码
velocity

package ${packageName}.controller;

import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;

@Api(tags = "${functionName}Controller")
@RestController
@RequestMapping("/${moduleName}/${businessName}")
public class ${ClassName}Controller extends BaseController {
    
    @ApiOperation("查询${functionName}列表")
    @PreAuthorize("@ss.hasPermi('${permissionPrefix}:list')")
    @GetMapping("/list")
    public TableDataInfo list(${ClassName} ${className}) {
        startPage();
        List<${ClassName}> list = ${className}Service.select${ClassName}List(${className});
        return getDataTable(list);
    }
    
    @ApiOperation("获取${functionName}详细信息")
    @PreAuthorize("@ss.hasPermi('${permissionPrefix}:query')")
    @GetMapping(value = "/{${pkColumn.javaField}}")
    public AjaxResult getInfo(@PathVariable("${pkColumn.javaField}") ${pkColumn.javaType} ${pkColumn.javaField}) {
        return success(${className}Service.select${ClassName}By${pkColumn.capJavaField}(${pkColumn.javaField}));
    }
}
相关推荐
禅思院几秒前
Vite vs Webpack 深度对比:从启动原理到生产构建,一篇就够了
前端·架构·前端框架
IT_陈寒2 分钟前
Vue的响应式真把我坑惨了,原来问题出在这
前端·人工智能·后端
兵慌码乱9 小时前
基于Python+PyQt5+SQLite的药房管理系统实现:事务一致性与界面解耦全流程解析
python·sqlite·信号与槽·pyqt5·数据库设计·桌面应用开发·事务处理
朦胧之10 小时前
AI 编程-老项目改造篇
java·前端·后端
金銀銅鐵11 小时前
[Python] 体验用欧几里得算法计算最大公约数的过程
python·数学
swipe13 小时前
从 0 到 1 实现大文件上传:分片、秒传、断点续传、暂停、重试与服务端合并
前端·javascript·面试
爱勇宝13 小时前
我做了一个只用来搜歌词的小 App
android·前端·后端
甲维斯13 小时前
用AI还原《坦克大战》并3D化升级!
前端·人工智能·游戏开发
IT_陈寒14 小时前
SpringBoot自动配置坑了我一晚上,原来问题出在这
前端·人工智能·后端
FreakStudio14 小时前
W55MH32L-EVB 上手测评:硬件 TCP/IP 加持的以太网单片机,MicroPython 零门槛开发
python·单片机·嵌入式·大学生·面向对象·并行计算·电子diy·电子计算机