freemarker特殊字符用noparse转义#{}

自动生成mapper的时候遇到特殊字符需要转义,特此记录一下

如:

<#list mapperDataList as data>
    #{it.${data.columnName}},
</#list>

这样会报错

Caused by: freemarker.core.ParseException: Syntax error in template "mapper.ftl" in line 12, column 6:
You can't use "${" here as you are already in FreeMarker-expression-mode. Thus, instead of ${myExpression}, just write myExpression. (${...} is only needed where otherwise static text is expected, i.e, outside FreeMarker tags and ${...}-s.)
    at freemarker.core.TokenMgrError.toParseException(TokenMgrError.java:247)
    at freemarker.template.Template.<init>(Template.java:215)
    at freemarker.cache.TemplateCache.loadTemplate(TemplateCache.java:495)
    at freemarker.cache.TemplateCache.getTemplate(TemplateCache.java:409)
    at freemarker.cache.TemplateCache.getTemplate(TemplateCache.java:261)
    at freemarker.template.Configuration.getTemplate(Configuration.java:1786)
    at freemarker.template.Configuration.getTemplate(Configuration.java:1646)
    at com.code.generator.CodeGenerator.genMapperSql(CodeGenerator.java:292)
    ... 2 more

应该写成

<#list mapperDataList as data>
    <#noparse>#{</#noparse>it.${data.columnName}<#noparse>}</#noparse>,
</#list>

这样就能正确生成了。

<#noparse>的作用:

FreeMarker 不会在这个指令体中间寻找FTL标签, 插值和其他特殊的字符序列,除了noparse的结束标记。

 

### 回答1: Freemarker 中自定义标签需要使用宏(Macros)实现,其基本语法如下: ``` <#macro macroName arg1 arg2...> <!-- 宏定义 --> </#macro> ``` 其中 `macroName` 是宏的名称,`arg1, arg2...` 是宏的参数列表,可以根据需要添加参数。在模板中使用自定义标签时,需要使用 `<@macroName arg1=value1 arg2=value2.../>` 的方式调用宏,其中 `arg1=value1, arg2=value2...` 是宏参数的具体值。 例如,下面是一个自定义 `myList` 标签的示例: ``` <#macro myList listVar> <ul> <#list listVar as item> <li>${item}</li> </#list> </ul> </#macro> <@myList listVar=["apple", "banana", "orange"]/> ``` 在这个例子中,我们定义了一个名为 `myList` 的宏,它接收一个名为 `listVar` 的参数,该参数是一个 List 类型的数据。在宏定义中,我们使用 `<#list>` 标签遍历 `listVar` 中的元素,并将它们显示为一个无序列表。在模板中调用宏时,我们使用 `<@myList>` 标签,并将 `listVar` 参数设置为一个包含三个元素的 List。最终生成的输出如下: ``` <ul> <li>apple</li> <li>banana</li> <li>orange</li> </ul> ``` 你可以根据自己的需求修改宏定义,实现类似 `<#list>` 的自定义标签。 ### 回答2: FreeMarker是一种模板引擎,它可以用来生成各种格式的输出文本,包括HTML、XML、JSON等。在FreeMarker中,可以通过自定义指令(directive)来实现对模板的扩展和定制。 要自定义类似于`<#myDirective>`这样的指令,需要按照以下步骤进行操作: 1. 创建一个自定义指令类,可以实现`TemplateDirectiveModel`接口或者继承`Directive`类。这个类用于处理模板中对应指令的逻辑。 2. 在自定义指令类中,重写`execute`方法或`execute(Environment env, Map params, TemplateModel[] loopVars, TemplateDirectiveBody body)`方法,以实现指令的具体逻辑。 3. 在模板中使用自定义指令时,需要在模板中导入指令库,并使用`<#import>`指令导入自定义指令类所在的包路径。 4. 在模板中使用`<#myDirective>`这样的标签来调用自定义指令。 例如,以下是一个简单的自定义简化输出日期指令的示例: ```java public class DateDirective extends TemplateDirectiveModel { @Override public void execute(Environment env, Map params, TemplateModel[] loopVars, TemplateDirectiveBody body) throws TemplateException, IOException { // 获取参数 String format = params.get("format").toString(); // 获取当前时间 Date now = new Date(); // 格式化时间 SimpleDateFormat sdf = new SimpleDateFormat(format); String formattedDate = sdf.format(now); // 输出结果到模板 Writer out = env.getOut(); out.write(formattedDate); // 按需处理指令体内容 if (body != null) { body.render(env.getOut()); } } } ``` 在模板中使用: ```html <#import "com.example.DateDirective"> <#myDirective format="yyyy-MM-dd HH:mm:ss"/> ``` 以上是一个简单的示例,用于展示如何自定义类似`<#myDirective>`这样的指令。实际上,自定义指令的功能可以更为复杂,可以根据具体需求进行扩展和定制。 ### 回答3: 在Freemarker中,可以通过自定义指令(directives)来实现类似HTML标签的自定义标签。 首先,在Freemarker模板中,使用自定义指令时需要添加一个命名空间。可以通过以下方式添加命名空间: <#ftl ns_prefixes={"mydir":"com.example.mydirective"}> 然后,在JAVA代码中,需要创建一个实现TemplateDirectiveModel接口的自定义指令类。在这个类中,可以通过重写execute方法来实现自定义指令的逻辑。 以类似的自定义指令<mydir:mytag>为例,在execute方法中可以处理这个指令的逻辑。 接下来,在Freemarker模板中使用自定义指令。可以通过以下方式来使用自定义指令: <mydir:mytag param1="value1" param2="value2"> 在自定义指令的参数中,可以包含任意个数的属性,如上例中的param1和param2。自定义指令类可以通过调用env.getVariable()方法来获取这些属性的值。 最后,在自定义指令的execute方法中,根据参数值进行相应的处理。例如,可以根据参数值来生成特定的HTML标签,并将它添加到模板中。 总结起来,通过自定义指令,可以在Freemarker模板中实现类似HTML标签的自定义标签,提高代码的可读性和可维护性。自定义指令类可以在JAVA代码中实现,通过重写execute方法来处理自定义指令的逻辑。在模板中使用自定义指令时,可以传递任意个数的参数,自定义指令类可以根据这些参数值进行相应的处理。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值