转自:http://fhd001.iteye.com/blog/1167764
			
freemarker之模板开发(其它之自定义指令)
----------
自定义指令可以使用macro指令来定义,这是模板设计者所关心的内容。Java程序员若不想在模板中实现自定义指令,而是在java语言中实现指令的定义,这时可以使用:freemarker.template.TemplateDirectiveModel类来扩展。
					
 
 
宏
			
宏是有一个变量名的模板片段。你可以在模板中使用宏作为自定义指令,这样就能进行重复性的工作。
			
如例:
			
Html代码   
				
- <#macro greet>  
								 
-     <font size="+2">Hello Joe!</font>  
														 
- </#macro>  
								 
macro指令自身不打印任何内容,它只是用来创建宏变量,所以就会有一个名为greet的变量,在<#macro greet>和</#macro>之间的内容(称为宏定义体)当使用它作为指令时将会被执行。你可以在FTL标记中通过@代替#来使用自定义指令。使用变量名作为指令名。而且,自定义指令的结束标记也是需要的,如:<@greet></@greet>
						
因为<anything>,/anything>和<anything/>是相同的,你也可以使用:<@greet/>
宏能做的事情还有很多,因为在<#macro...>和</#macro>之间的东西是模板片段,也就是说它可以包含插值(${..})和FTL标签(如:<#if...>...</#if>)。
			
注意:程序员通常将使用<@...>,这称为宏调用。
			
 
 
参数
			
在macro指令中,宏名称的后面位置是用来定义变量的。如例: 
Html代码   
				
- <#macro greet person>  
								 
-     <font size="+2">Hello ${person}!</font>  
														 
- </#macro>  
								 
那么就可以这样来使用这个宏:
			
Html代码   
				
- <@greet person="Fred"/>  
											 
使用预定义指令时,参数的值(=号后边的值)可以是FTL表达式。这样,不像HTML,"Fred"的引号就可以不用要了。<@greet person=Fred/>也意味着使用变量的值Fred作为person参数,而不是字符串"Fred"。当然参数值并不一定是字符串类型,也可以是数字,布尔值,哈希表,序列等...也可以在=号左边使用复杂表达式(比如:someParam=(price+50)*1.25)
自定义指令可以有多个参数,如:  
Html代码   
				
- <#macro greet person color>  
								 
-     <font size="+2" color="${color}">Hello ${persion}!</font>  
																		 
- </#macro>  
								 
那么,这个宏就可以这样来使用:
			
Html代码   
				
- <@greet person="Fred" color="black"/>  
															 
同时也必须给出在宏中定义所有参数的值。如果你尝试<@greet person="Fred"/>时也会发生错误,因为忘记指定color的值了。 
根据FTL表达式规则,明白下面这一点是至关重要的,someParam=foo和someParam="${foo}"是不同的。第一种情况,是把变量foo的值作为参数的值来使用。第二种情况则是使用插值形式的字符串,那么参数值就是字符串了,这个时候,foo的值呈现为文本,而不管foo是什么类型的。
			
宏参数的另外一个重要的方面是它们是局部变量。
			
 
 
嵌套内容
			
自定义指令可以嵌套内容,和预定义指令相似。如: 
Html代码   
				
- <#macro border>  
								 
-     <table border=4 cellspacing=0 cellpadding=4><tr><td>  
																				 
-         <#nested>  
									 
-     </td></tr></table>  
							 
- </#macro>  
								 
注:<#nested>指令执行位于开始和结束标记指令之间的模板代码段。如果这样写:
			
Html代码   
				
- <@border>The bordered text</@border>  
												 
那么就会输出:
			
Html代码   
				
- <table border=4 cellspacing=0 cellpadding=4><tr><td>  
																			 
-     The bordered text  
					 
- </td></tr></table>  
						 
如果不使用nested指令,那么嵌套的内容就不会被执行,前面的例子如果这样写:
			
Html代码   
				
- <@greet person="Joe">  
											 
-     Anything.  
					 
- </@greet>  
								 
FreeMarker不会把它视为错误,只是打印:
			
Html代码   
				
- <font size="+2">Hello Joe!</font>  
													 
嵌套的内容被忽略了,因为greet宏没有使用nested指令。
			
 
 
宏和循环变量
			
像list这样的预定义指令可以使用循环变量,如例:
			
Html代码   
				
- <#macro do_thrice>  
								 
-     <#nested 1>  
									 
-     <#nested 2>  
									 
-     <#nested 3>  
									 
- </#macro>  
								 
用户自定义指令,使用";"代替"as"
					
Html代码   
				
- <@do_thrice ; x>  
								 
-     ${x} Anything.  
					 
- </@do_thrice>  
								 
将会输出:
			
1 Anything.
2 Anything.
3 Anything.
nested指令(当然参数可以是任意的表达式)的参数,循环变量的名称是在自定义指令的开始标记(<@...>)的参数后面通过分号确定的。
			
	posted on 2012-06-21 10:04 
Libo 阅读(788) 
评论(0)  编辑  收藏