FreeMarker模板引擎常用指令

来源:互联网 发布:python编程第四版云盘 编辑:程序博客网 时间:2024/05/23 11:57

一、FreeMarker简介

FreeMarker 是一款模板引擎:即一种基于模板、用来生成输出文本(任何来自于 HTML格式的文本用来自动生成源代码)的通用工具。

FreeMarker 实际上是被设计用来生成 HTML 页面,尤其是通过实现了基于 MVC(Model View Controller, 模型-视图-控制器)模式的 Java Servlet 应用程序。

 

二、FreeMarker常用指令

模板 +  数据模型 = 输出

<1>、if指令使用示例

Html代码  收藏代码
  1. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">    
  2. <html>  
  3.   <head>  
  4.     <title>IF_Tag_Demo</title>  
  5.     <meta http-equiv="Content-Type" content="text/html;" charset="UTF-8">  
  6.   </head>  
  7.   <body>  
  8.         <#if x == 1>  
  9.         x is 1  
  10.     </#if>  
  11.         <br/>  
  12.         <#if x == 1>  
  13.         x is 1  
  14.     <#else>  
  15.         x is not 1  
  16.     </#if>  
  17.     <br/>  
  18.     <#if x == 1>  
  19.         x is 1  
  20.     <#elseif x == 2>  
  21.         x is 2  
  22.     <#elseif x == 3>  
  23.         x is 3  
  24.     </#if>  
  25.   </body>  
  26. </html>  

 <2>switch指令使用示例

Html代码  收藏代码
  1. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">    
  2. <html>  
  3.   <head>  
  4.     <title>Switch_Tag_Demo</title>  
  5.     <meta http-equiv="Content-Type" content="text/html;" charset="UTF-8">  
  6.   </head>  
  7.   <body>  
  8.         <#switch x>  
  9.     <#case 1>  
  10.         1  
  11.         <#break>  
  12.     <#case 2>  
  13.         2  
  14.         <#break>  
  15.     <#case 3>  
  16.         3     
  17.         <#break>  
  18.     <#default>  
  19.         0  
  20.         <#break>  
  21.     </#switch>  
  22.   </body>  
  23. </html>  

 <3>、list指令使用示例

Html代码  收藏代码
  1. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">    
  2. <html>  
  3.   <head>  
  4.     <title>List_Tag_Demo</title>  
  5.     <meta http-equiv="Content-Type" content="text/html;" charset="UTF-8">  
  6.   </head>  
  7.   <body>  
  8.     <h1>${title}</h1><br/>  
  9.     <table>  
  10.         <tr>  
  11.             <td>学号</td>  
  12.             <td>姓名</td>  
  13.             <td>性别</td>  
  14.         </tr>  
  15.         <#list students as s>  
  16.         <tr>  
  17.             <td>${s.no}</td>  
  18.             <td>${s.name}</td>  
  19.             <td>${s.sex}</td>  
  20.         </tr>  
  21.         </#list>   
  22.     </table>  
  23.   </body>  
  24. </html>  

 <4>、assign指令使用示例

Html代码  收藏代码
  1. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">    
  2. <html>  
  3.   <head>  
  4.     <title>Assign_Tag_Demo</title>  
  5.     <meta http-equiv="Content-Type" content="text/html;" charset="UTF-8">  
  6.   </head>  
  7.   <body>  
  8.         <#assign msg="世界你好!">  
  9.         <h1>${msg}</h1>  
  10.   </body>  
  11. </html>  

 <5>、macro指令使用示例

Html代码  收藏代码
  1. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">    
  2. <html>  
  3.   <head>  
  4.     <title>Macro_Tag_Demo</title>  
  5.     <meta http-equiv="Content-Type" content="text/html;" charset="UTF-8">  
  6.   </head>  
  7.   <body>  
  8.     <#-- 定义 -->  
  9.         <#macro greet>  
  10.         <font size="+2">世界你好!</font>  
  11.     </#macro>  
  12.     <#macro greet2 person>  
  13.         <font size="+2">Hello ${person}!</font>  
  14.     </#macro>  
  15.     <#macro greet3 person color="black">  
  16.         <font size="+2" color="${color}">Hello ${person}!</font>  
  17.     </#macro>  
  18.     <#macro border>  
  19.         <table border=4 cellspacing=0 cellpadding=4>  
  20.             <tr>  
  21.                 <td>  
  22.                 <#nested> <#-- 嵌套内容  -->  
  23.                 </td>  
  24.             </tr>  
  25.         </table>  
  26.     </#macro>  
  27.       
  28.     <#-- 使用 -->  
  29.     <@greet></@greet>   <br>  
  30.     <@greet2 person="xieke"/> <br>  
  31.     <@greet3 person="xieke"/> <br>  
  32.     <@greet3 person="xieke" color="red"/> <br>  
  33.     <@border>The bordered text</@border>  
  34.   </body>  
  35. </html>  

   更多示例以及上述示例实际效果可以自行下载源代码查看,下载地址:http://pan.baidu.com/s/1jHEF6g2


  转载请注明出处: http://xieke90.iteye.com/blog/2302962

原创粉丝点击