Struts2讲义28

系统 1962 0

6.2   freemarker 视图技术使用介绍

freemarker velocity 一样也是一种可以替代 JSP 的视图技术。而且 Struts2 中对它的支持要比对 velocity 也强大的多。下面就对它进行介绍。

技术要点

本节代码说明 freemarker Struts2 中使用方式。

freemarker 基本语义和书写格式说明。

模板文件 ftl 介绍

Struts2 中如何使用 freemarker

演示代码

显示数据的 ftl 模板文件代码:

Java代码 复制代码
  1. <!-------------------文件名:show.ftl------------->   
  2. <html>   
  3.     <head>   
  4.     <title>FreeMarker使用范例</title>   
  5.     <meta http-equiv= "content-type"  content= "text/html; charset=GB2312" />   
  6.     </head>   
  7.     
  8.     <body>   
  9.        <h3 align= "left" >   
  10.             FreeMarker使用范例   
  11.         </h3>   
  12.        <h1>装修材料信息列表</h1>   
  13.           
  14.         <table border>   
  15.         <tr align= "center" >   
  16.           <td>材料名</td>   
  17.           <td>材料价格(单位:元)</td>   
  18.           <td>材料库存量(单位:个)</td>   
  19.         </tr>   
  20.         <#list mList as Material>   
  21.               <tr align= "center" >   
  22.                   <td>${Material.material}</td>   
  23.                   <td>${Material.bid}</td>   
  24.                   <td>${Material.mount}</td>   
  25.              </tr>   
  26.         </#list>   
  27.        </table>   
  28.     </body>   
  29. </html>  
    <!-------------------文件名:show.ftl------------->
<html>
    <head>
    <title>FreeMarker使用范例</title>
    <meta http-equiv="content-type" content="text/html; charset=GB2312"/>
    </head>
 
    <body>
       <h3 align="left">
            FreeMarker使用范例
        </h3>
       <h1>装修材料信息列表</h1>
       
        <table border>
        <tr align="center">
          <td>材料名</td>
          <td>材料价格(单位:元)</td>
          <td>材料库存量(单位:个)</td>
        </tr>
        <#list mList as Material>
              <tr align="center">
                  <td>${Material.material}</td>
                  <td>${Material.bid}</td>
                  <td>${Material.mount}</td>
             </tr>
        </#list>
       </table>
    </body>
</html>
  

 

Action 代码同 velocity 示例中 Action 代码,这里就不显示了。读者自行阅读。

配置文件对 Action 的配置内容:

Java代码 复制代码
  1. <!-----------文件名:struts.xml----------->   
  2. ………   
  3. < package  name= "C06.1"   extends = "struts-default" >   
  4.                    <action name= "velocity"   
  5.                              class = "action.VelocityAction" >   
  6.                             <result name= "success"  type= "freemarker" >/velocity/show.vm</result>   
  7.                    </action>   
  8. </ package >  
    <!-----------文件名:struts.xml----------->
………
<package name="C06.1" extends="struts-default">
                   <action name="velocity"
                            class="action.VelocityAction">
                            <result name="success" type="freemarker">/velocity/show.vm</result>
                   </action>
</package>
  

 

对支持中文字符的字符编码集设置也如 velocity 示例。示例效果显示如图 6.2

Struts2讲义28

6.2   freemarker 显示效果图

代码解释

1 )本节示例也是将一些装修材料用 list 形式显示在页面上。只不过现在使用的是 freemarker 。它其实是将 JAVA 代码中定义好的类,在底层使用 map 类型显示在页面上。因此在 ftl 模板中看见的“ # ”标识除了表明控制转向之外,其他都是 map key 值,而每个 key 值对应的 value 就是 JAVA 中定义的类,这些类有可能是 JavaBean 也有可能像本示例中的材料列表一样是 list 和其他数据集合类。“ $ ”标识和 velocity 中“ $ ”标识类似是用来标识具体对象或变量。

2 freemarker 模板文件后缀名都是“ ftl ”结尾。它也可以在文件中定义各种各样的 html 标签和代码。不过它要调用 Struts2 的标签则调用方法要比 vm 文件调用 Struts2 标签要稍微复杂点。

首先在它的文件头部使用 assign 来导入 Struts2 的标签定义。代码如下:

Java代码 复制代码
  1. <#assign s=JspTagLibs[“/WEB-INF/struts-tags.tld”]/>  
    <#assign s=JspTagLibs[“/WEB-INF/struts-tags.tld”]/>
  

 

另外在每次调用 Struts2 标签时候前面要加上“ @ ”。

3 )在 Struts2 中使用 freemarker 技术,首先要在项目中导入 freemarker jar 包。 struts.xml 文件中,同样笔者用黑体注明了 result 的返回类型必须是“ freemarker ”,这样才可以调用 ftl 模板文件。关于中文字符支持问题的解决方法也如笔者介绍 velocity 的小节中相同。

注意: ftl 文件中对英文字符的大小写是很敏感的,因此对某些对象和变量的定义时候,请读者注意大小写问题。

Struts2讲义28


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论