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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • svn中文语言包安装无反应_英文版win7安装语言包

    svn中文语言包安装无反应_英文版win7安装语言包1.中文语言包下载地址,两种下载方式:下载(1.9.4版本):https://sourceforge.net/projects/tortoisesvn/files/1.9.4/Language%20Packs/官网下载:https://tortoisesvn.net/downlo…

    2025年7月6日
    2
  • 通过主机名得到对应ip地址_如何查看电脑主机名或Ip地址

    通过主机名得到对应ip地址_如何查看电脑主机名或Ip地址
         由于SILVERLIGHT是基于纯客户端的机制实现的,想在SL中获取客户端计算机信息暂时还没有效的解决方案。
    一般都是基于WCF、WebService等在服务端获取发送请求机器的信息,然后再返回客户端,该方法可以实现;
    同时可以在

    2022年10月9日
    2
  • 关于W25Q128地址的定义

    1.W25Q128将16M的内存分为256个块,每个块是64K;又将一个块分为16个扇区,一个扇区是4K;又将一个扇区分为16个页,一个页是256字节地址。话不多说,上图:2.在图上右边的红框中可以看到Block0(块0)的地址是000000-00FFFF,再看到左边红框中Block0的16个扇区,地址范围对应的就是Block0的地址范围了,第一个扇区的起始地址就是0000,终止地址是0F…

    2022年4月6日
    146
  • SAE J1939物理层

    SAE J1939物理层在SAEJ1939-11和ISO11898中对商用车使用的线束都是屏蔽双绞线,即为除了电源、地、CAN_H、CAN_L之外还有一个屏蔽线,并且所有ECU的屏蔽线都接到同一个地线上,一般接地点选择在网络的中央位置上。但是在实际使用中,多数整车厂使用的都是非屏蔽双绞线,比较而言,非屏蔽双绞线的EMC特性要差一些,在1939中正常使用屏蔽双绞线一路CAN网络上最多可以接入30个ECU,而对于非屏蔽双

    2022年5月22日
    33
  • 2021idea激活码【2021免费激活】

    (2021idea激活码)JetBrains旗下有多款编译器工具(如:IntelliJ、WebStorm、PyCharm等)在各编程领域几乎都占据了垄断地位。建立在开源IntelliJ平台之上,过去15年以来,JetBrains一直在不断发展和完善这个平台。这个平台可以针对您的开发工作流进行微调并且能够提供…

    2022年3月26日
    109
  • portraiture 3 mac(最强ps人像美化磨皮滤镜)内附安装教程

    portraiture 3 mac(最强ps人像美化磨皮滤镜)内附安装教程imagenomicportraituremac是一款非常强大的ps人像美化磨皮滤镜,可以更好的辅佐我们的ps进行人像滤镜美化处理。portraituremac激活成功教程版能够智能的对图像中的肤色、毛发以及眉毛等部位进行滤镜抛光处理,细节处理,以减少瑕疵。portraituremac激活成功教程版基本上是人人都能用得上的ps辅助工具,有了它处理人像效果更加显著。小编现为您带来portraiture3滤镜下载,需要的小伙伴快来下载吧!下载地址:https://mac.orsoon.com/Mac/167.

    2022年7月22日
    11

发表回复

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

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