首先是我们自定义的工具类FreeMarkerUtiljava
package comjadyerutil;import javaioBufferedWriter;
import javaioFile;
import javaioFileOutputStream;
import javaioIOException;
import javaioOutputStreamWriter;
import javaioPrintWriter;
import javaioWriter;
import javautilMap;
import freemarkertemplateConfiguration;
import freemarkertemplateTemplate;
import freemarkertemplateTemplateException;
public class FreeMarkerUtil {
/
@param name 模板文件的名称
@param pathPrefix 模板文件的目录
/
public Template getTemplate(String name, String pathPrefix) throws IOException{
Configuration cfg = new Configuration(); //通过FreeMarker的Configuration对象可以读取ftl文件
cfgsetClassForTemplateLoading(thisgetClass(), pathPrefix); //设置模板文件的目录
cfgsetDefaultEncoding("UTF-8"); //Set the default charset of the template files
Template temp = cfggetTemplate(name); //在模板文件目录中寻找名为"name"的模板文件
return temp; //此时FreeMarker就会到类路径下的"pathPrefix"文件夹中寻找名为"name"的模板文件
}
/
根据模板文件输出内容到控制台
@param name 模板文件的名称
@param pathPrefix 模板文件的目录
@param rootMap 模板的数据模型
/
public void print(String name, String pathPrefix, Map<String,Object> rootMap) throws TemplateException, IOException{
thisgetTemplate(name, pathPrefix)process(rootMap, new PrintWriter(Systemout));
}
/
根据模板文件输出内容到指定的文件中
@param name 模板文件的名称
@param pathPrefix 模板文件的目录
@param rootMap 模板的数据模型
@param file 内容的输出文件
/
public void printFile(String name, String pathPrefix, Map<String,Object> rootMap, File file) throws TemplateException, IOException{
Writer out = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(file), "UTF-8"));
thisgetTemplate(name, pathPrefix)process(rootMap, out); //将模板文件内容以UTF-8编码输出到相应的流中
if(null != out){
outclose();
}
}
}
2下面是位于//src//ftl//包中用于演示自定义指令的用法的macroftl
<#-- 自定义指令 --><#-- 自定义一个名字为myMacro的指令 -->
<#-- 该指令的作用就是输出<h2>Hi:macro</h2>,调用该指令时使用<@myMacro/>即可 -->
<#macro myMacro>
<h1>Hi:macro</h1>
</#macro>
<@myMacro/>
<#-- 自定义一个带有参数的名字为myMacro22的指令 -->
<#-- 这里myMacro22后面跟的都是参数,这里有两个参数,分别为num和name -->
<#macro myMacro22 num name>
<#list 1num as n>
<h2>hello:${name}${n}${n}</h2>
</#list>
</#macro>
<@myMacro22 4 "blackjade"/>
<@myMacro22 num=4 name="Jadyer"/>
<#-- 为指令参数定义初始值 -->
<#-- 此时就可以直接调用<@myMacro33/>而不会报错了。注意:指定初始值的参数要放在未指定初始值参数的后面 -->
<#macro myMacro33 num=3 name="JADYER">
<#list 1num as n>
<h3>welcome:${name}${n}${n}</h3>
</#list>
</#macro>
<@myMacro33/>
<@myMacro33 num=4 name="myblog"/>
<#-- 使用<#nested/>可以输出指令中的内容,输出的次数与<#nested/>的数量有关 -->
<#macro myMacro44>
<#nested/>
<#nested/>
</#macro>
<@myMacro44>
<h4>;
3下面是位于//src//ftl//包中用于演示四种变量的用法的assignftl
<#--变量,分为以下四类
模型变量----rootMap中的变量
模板变量----使用<#assign>定义的变量
局部变量----指令中的变量
循环变量----循环中的变量
-->
<#assign myname="Jadyer"/>
<#-- 此时模板变量名称与模型变量名称相同,虽然打印的是模板变量值,但模型变量值并没有被覆盖,而被隐藏了 -->
<#-- 并且这两个变量是存在于不同空间中的,如此才给人一种"被隐藏"的意识,这是FreeMarker中很重要的一个概念 -->
<#-- 在调用变量的时候,实际上它会先到模板变量中查找,没有则去模型变量中查找 -->
${myname}
<#-- 通过这种方式就可以访问模型变量了 -->
${globalsmyname}
<#-- 调用该指令后,会将模板变量myname的值覆盖为JADYER。注意此时是覆盖,不是隐藏,相当于模板的覆盖模板的 -->
<#macro myMacro>
<#assign myname="JADYER"/>
</#macro>
<#-- 由于此时还没有调用myMacro指令,故打印的仍是最上面定义的模板变量值Jadyer -->
${myname}
<@myMacro/>
<#-- 由于此时已经调用了myMacro指令,故打印的是模板中的变量被覆盖后的值JADYER -->
${myname}
<#-- 上面那种在指令中定义变量的方式存在风险,容易误将模板变量中同名的变量覆盖 -->
<#-- 而使用<#local/>定义的变量则不会覆盖模板变量,且此时的变量就属于局部变量了 -->
<#macro myMacro22>
<#local myname="}
4最后是使用JUnit4x编写的测试类FreeMarkerTestjava
package comjadyertest;import javaioIOException;
import javautilHashMap;
import javautilMap;
import orgjunitBefore;
import orgjunitTest;
import comjadyerutilFreeMarkerUtil;
import freemarkertemplateTemplateException;
public class FreeMarkerTest {
String pathPrefix;
Map<String,Object> rootMap;
FreeMarkerUtil fmu;
@Before
public void setUp(){
pathPrefix = "/ftl";
rootMap = new HashMap<String,Object>();
fmu = new FreeMarkerUtil();
}
@Test
public void printMacro() throws TemplateException, IOException{
fmuprint("macroftl", pathPrefix, rootMap);
}
@Test
public void printAssign() throws TemplateException, IOException{
rootMapput("myname", "XuanYu"); //这个变量就是数据模型中的变量,即模型变量
fmuprint("assignftl", pathPrefix, rootMap);
}
}
不知道你的validator里面怎么写的哦,执行顺序是怎么样的。
可以尝试在后面改变tempftl中出现的效果。比如
success:function(label,element){
$(element)next()hide();
alert("aaaaaa");
}
ftl不可以和jsp共存的,二者具有转化关系。
freemarker(FTL)常见语法(JSP中的代码转化为ftl代码) 举例如下:
1、引入公共页面<#include "paramsftl">
2、判断是否为空:<#if (resultContextpaginationresultList) && resultContextpaginationresultListsize gt 0>
3、集合遍历:
<#list list as a>
${a_index+1}
</#list>
4、访问Java类中的静态方法
<#if st == stackfindValue("@comtestboSkuTag@NEW")><#elseif st == stackfindValue("@comtestboSkuTag@SPECIAL") >
5、访问Request对象
${RequesteffectTypeinfoName!'' } 其他域对象比如:Session对象 貌似还是是${Session}
6、使用其他标签如struts2标签:
引入tld:<#assign ts=JspTaglibs["/skw-tags"] /> 使用: <@tsproductPrice loginUrl="${ctxtPath}/login_jsphtml"/>
以上就是关于html标签存在数据库中,ftl文件读取该数据库文件时把html标签显示在前台页面上了怎么解决全部的内容,包括:html标签存在数据库中,ftl文件读取该数据库文件时把html标签显示在前台页面上了怎么解决、在html页面中包含<#include (ftl文件) />这是什么语法,提供点相关资料!、spring boot和freemarker项目中怎么从一个ftl页面直接跳转到另外一个ftl页面,不经过后台等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)