velocity定义_velocity模板

velocity定义_velocity模板文章目录基本用法导入依赖1.基本用法1.1注释1.2替换变量1.3不解析,原文输出1.4调用对象方法指令setifelse基本用法导入依赖<dependency> <groupId>org.apache.velocity</groupId><artifactId>velocity</artifactId><version>1.7</version></dependency&

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

基本用法

导入依赖

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

创建一个公共方法,它是通过类路径来获取模板的,接下来就可以开始测试了!

public class VelocityUtils { 
   
/** * 执行模板渲染 * @param inputPath 输入路径 * @param velocityContext 内容 */
    public static String replace(String inputPath ,VelocityContext velocityContext){ 
   
        if(!inputPath.startsWith("\\")){ 
   
            inputPath="\\"+inputPath;
        }
        // 初始化模板引擎
        VelocityEngine ve = new VelocityEngine();
        ve.setProperty(Velocity.INPUT_ENCODING, "UTF-8");
        ve.setProperty(Velocity.OUTPUT_ENCODING, "UTF-8");
        ve.setProperty(RuntimeConstants.RESOURCE_LOADER, "classpath");
        ve.setProperty("classpath.resource.loader.class", ClasspathResourceLoader.class.getName());
        //TODO 绝对路径
// ve.setProperty(Velocity.FILE_RESOURCE_LOADER_PATH, System.getProperty("user.dir") + "\\config\\" );
        ve.init();
        // 获取模板文件
        Template t = ve.getTemplate(inputPath);
        StringWriter sw = new StringWriter();
        t.merge(velocityContext,sw);
        //测试查看
        System.out.println(sw.toString());
        return sw.toString();
    }
}

测试类

public class Test { 
   
    //获取模板
    private VelocityContext get(){ 
   
        VelocityContext context = new VelocityContext();
        context.put("name","王尼玛");
        Student stu = new Student();
        stu.setAge(23);
        stu.setName("王小二");
        stu.setBirth(new Date());
        context.put("stu",stu);
        return context;
    }
    @Test
    public void test1(){ 
   
        VelocityContext context = get();
        //放在resources目录下
        VelocityUtils.replace("/test/test1.html.vm",context);
    }
}

1.基本用法

1.1 注释

##注释
#**
 * TODO 多行注释
 *#

1.2 替换变量

## 基础
hello, ${name}  $name

## 若有数据则输出,无则输出空串
H$!{ 
   name}H   无$!{ 
   name2}

这里要注意:尽量用标准的写法${},否则容易导致语法错误
这里要注意:

1.3 不解析,原文输出

## 不解析
#[[------
    非解析内容
    ${name}
-----]]#

输出结果

	非解析内容
    ${name}

1.4 调用对象方法

${stu.name}  ${stu.getStr()}
#set($name = "abc def")
$name.split(" ")[0]   --结果是abc

vtl 指令

set (String、int、Boolean、List、Map)

在这里插入图片描述
结果:

王尼玛 18
[1, 2, 3, 4, 5]  2
true
{ 
   name=Mike, age=12, isBoy=true}  Mike

if 、else

这个简单理解

#if($prop.name!='username' && $prop.name!='password')
..
#elseif($prop.name=='id')
..
#else
..
#end

其中,if可以识别为true的内容为:非null(java的String空串,也是识别为true!)、Boolean=true

foreach

#break可以终止循环

#循环遍历List 
#foreach($prop in $struct.cppPropList)
	$prop
#end

遍历map
在这里插入图片描述

循环内部$foreach的属性使用:

在这里插入图片描述

include 、 parse

基于类路径(在VelocityEngine 中设置读取的基本路径)

#include 包含,不会被velocity解析

#parse 会被velocity解析

#include("/template/utils/compare.vm")
#parse("/template/component/menu.vm")

define

用于定义某个公共模块,在调用之前我们可以提前定义好一些参数,然后通过模块名去调用

#set($name = "小白")
#define($common)
    hello,$name,你好呀!
#end
#set($name = "王尼玛")
$common
#set($name = "张三")
$common

在这里插入图片描述

evaluate

可以后端保存velocity语句,传入解析:

比如我们在java中:

context.put("v","#set($name = \"王尼玛\")");

模板内容如下:

#evaluate($v)
$name

解析结果:王尼玛

macro

#macro(method $name $age)
    hello!  $name, your age:$age
#end
## 调用宏,结果:hello! Mike, your age:13
#method("Mike",13)

在这里插入图片描述

macro的注意

在使用中,有时候会用到嵌套循环,看一个例子。

java中定义一个list,内有 w1 w2 ccc 3个字符串

List<String> authRoleFind = new ArrayList<String>();
authRoleFind.add("w1");
authRoleFind.add("w2");
authRoleFind.add("ccc");
context.put("list",authRoleFind);

首先定义一个宏
在这里插入图片描述
这个时候,在一个和宏内调用了相同的List的循环,想当然的预想结果应该是:

w1 -> w1
w1 -> w2
w1 -> ccc
w2 -> w1
w2 -> w2
w2 -> ccc

在这里插入图片描述
但是它的结果却是这样的.$auth -> $name始终相等了!
在这里插入图片描述
那就和这个方法的结果一样了!
在这里插入图片描述
不知道有什么好的解决方案,反正不能用C、Java函数的思想去思考了。

或许它是将 #macro 的内容,直接copy过去再进行 编译/执行 ?

解决:在引入时,我们要防止调用时参数的名字 和 #macro中的变量名冲突!
像上面那个例子,#macro 内容中,就已经使用了$name这个参数了,所以在调用的时候#methodFind()中不要再有$name

在这里插入图片描述

小结:我们在调用一个宏的时候 例#macro(methodFind $a $b) ,尽量以相同的参数名去调用#methodFind($a $b),以防止参数名冲突

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/180158.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • SQL Server中的sp_executesql系统存储过程

    SQL Server中的sp_executesql系统存储过程sp_executesql语法 sp_executesql[@stmt=]stmt[    {,[@params=]N@parameter_name  data_type[,…n]}    {,[@param1=]value1[,…n]}] 参数[@stmt=]stmt 包含 Transact-SQL 语

    2022年5月21日
    35
  • 什么是kit_django4.0

    什么是kit_django4.0#介绍ImageKit是用于处理图像的Django应用程序。如果需要从原图上生成一个长宽为50×50的图像,则需要ImageKit。ImageKit附带了一系列图像处理器,用于调整大小和裁剪等常见

    2022年7月31日
    7
  • 海思Hi3798MV200机顶盒芯片处理器简介

    海思Hi3798MV200机顶盒芯片处理器简介Hi3798MV200是用于IPTV/OTT机顶盒市场的支持4KP60解码的全4K高性能SOC芯片。集成4核64位高性能CortexA53处理器和多核高性能2D/3D加速引擎;支持H.2654Kx2K@P6010bit超高清视频解码,高性能的H.265高清视频编码,HDR视频解码及显示,Dolby和DTS音频处理;内置USB2.0、USB3.0、SDIO3.0、PCIe2.0等丰富外设接口。…

    2022年6月26日
    403
  • LoadLibrary失败,GetLastError= 193

    LoadLibrary失败,GetLastError= 193LoadLibrary失败,GetLastError=193LoadLibrary失败,GetLastError报错193时,一般是加载的dll所依赖的某个dll它的依赖项不存在所报的错,可以用DependencyWalker验证该dll所依赖的加载项是否都存在。DependencyWalker安装vs时一般都自带有,如果没有也可以去官网下载http://www.dependencywal…

    2022年7月13日
    15
  • Vagrant 基本使用操作

    Vagrant 基本使用操作OthersVagrant基本使用操作Vagrant是什么?Vagrant安装Vagrant快速上手安装CentOSVagrant基本命令小结Vagrantfile文件Vagrant基本使用操作Vagrant是什么?Vagrant是一款支持自动化虚拟机暗转、可配置流程的用于管理虚拟机的软件.主要的优势在于可以提供一个可配置、可移植和复用的虚拟机环境(通过定义Vagr…

    2025年7月29日
    4
  • double转bigDecimal精度问题

    double转bigDecimal精度问题double转bigDecimal精度问题需要用到bigDecimal的字符串构造来转float的精度:2^237位double的精度:2^5216位十进制转二进制存在精度差doubleg=12.35;BigDecimalbigG=newBigDecimal(g).setScale(1,BigDecimal.ROUND_HALF_UP);//…

    2022年6月4日
    165

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号