Java中Freemarker TemplateDirectiveModel自定义标签详解

本文详细介绍了如何在Java中利用Freemarker的TemplateDirectiveModel接口创建自定义标签。通过实现execute方法,处理系统环境变量、标签参数、循环变量和标签内容,实现对模板输出的任意操作。同时,文章提到了配置Spring Bean以及在FTL文件中引用自定义标签的注意事项,强调了空标签不能在同一行书写以避免错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

java中freemarker通过实现TemplateDirectiveModel接口,用户可以自定义标签(指令)进行任意操作,任意文本写入模板的输出。

定义

public void execute(Environment env, Map params, TemplateModel[] loopVars, TemplateDirectiveBody body) throws TemplateException, IOException;

env:系统环境变量,通常用它来输出相关内容,如Writer out = env.getOut()。

params:自定义标签传过来的对象,其key=自定义标签的参数名,value值是TemplateModel类型,而TemplateModel是一个接口类型,通常我们都使用TemplateScalarModel接口来替代它获取一个String 值,如TemplateScalarModel.getAsString();当然还有其它常用的替代接口,如TemplateNumberModel获取number,TemplateHashModel等。

loopVars 循环替代变量。

body 用于处理自定义标签中的内容,如<@myDirective>将要被处理的内容/@myDirective;当标签是<@myDirective />格式时,body=null。

创建自定义标签
1. 实现TemplateDirectiveModel这个接口中的execute方法

public class UserListDirective implements TemplateDirectiveModel{
    @Autowired
    private UserDAO  userDao;
    @Override
    public void execute(Environment env, Map params, TemplateModel[] loopVars,
            TemplateDirectiveBody body) throws TemplateException, IOException {
        String name = params.get("name").toString();
        List<User> userlist = userDao.findByProperty("name", name);

        env.setVariable("userList", getBeansWrapper().wrap(userlist));
        body.render(env.getOut());
    }
    public static BeansWrapper getBeansWrapper(){
        BeansWrapper beansWrapper = new BeansWrapperBuilder(Configuration.VERSION_2_3_21).build();
        return beansWrapper;
    }
}

2. 配置UserListDirective 到spring bean xml中

<bean id="userListDirective" class="com.action.directive.UserListDirective"></bean>

3. 将spring bean 设置到freemarkerConfig全局变量中

<bean id="freemarkerConfig2" class="org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer">
<property name="templateLoaderPath" value="/" />
<property name="freemarkerVariables">
    <map >  <entry key="userListDirective" value="userListTag" />
    </map>
</property>
<property name="freemarkerSettings">
    <props>  <prop key="template_update_delay">0</prop>  <prop key="defaultEncoding">UTF-8</prop>  <prop key="url_escaping_charset">UTF-8</prop>  <prop key="locale">zh_CN</prop>  <prop key="boolean_format">true,false</prop>  <prop key="datetime_format">yyyy-MM-dd HH:mm:ss</prop>  <prop key="date_format">yyyy-MM-dd</prop>  <prop key="time_format">HH:mm:ss</prop>  <prop key="number_format">0.######</prop>  <prop key="whitespace_stripping">true</prop>
    </props>
</property>
</bean>

4. ftl文件中引用userList自定义标签

<@userListTag name="51gjie">
    <#if userList?? && userList?size gt 0>
        <#list userList as user>
            ${user.name}
        </#list>
    </#if>
</@userListTag>

总结

  1. Freemarker自定义标签需要自定义一个类,然后实现TemplateDirectiveModel,重写execute方法,完成获取参数,根据参数设置不通属性等等。

  2. Freemarker自定义标签中,如果标签内什么也没有,开始标签和结束标签绝对不能再同一行,不然会报错。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值