• Velocity Macro


     1 #macro(formatIncreaseData $increase)
     2     #if(${product.onlineStatusFlag} =='0')
     3         --
     4     #elseif(!$increase || $increase=="")
     5         --
     6     #else
     7         #if($increase >= 0)
     8             #set($color = "increase-number")
     9         #elseif($increase < 0)
    10             #set($color = "is-decrease")
    11         #end
    12         <span class="$!{color}">${NumberUtils.percentageFormat($!{increase})}</span>
    13     #end
    14 #end
     1 #macro(renderTheme $themeList)
     2     #if($themeList.size()>0)
     3         #foreach($renqi in $themeList)
     4             #set($themeSelected="")
     5             #set($closeIcon = "")
     6             #if($!{fundGroupId} == $renqi.id)
     7                 #set($themeSelected="cur")
     8                 #set($closeIcon = "<span class='closeIcon'></span>")
     9             #end
    10         <li><a class="theme-name $!{themeSelected}" data-sk="All-reMen" title="$!{renqi.memo}" href=" " data-identity="fundGroupId" data-val="$!{renqi.id}"><span  class="">$!{renqi.groupName}</span>
    11             $!{closeIcon}
    12         </a >
    13         </li>
    14         #end
    15     #end

    Velocity中的宏可以理解为函数的定义,在使用的时候,需要考虑到宏的作用域的问题。

    1、外层的宏中的变量在内存的宏中可以访问

    2、内层中的宏变量如果与外层的变量名冲突,如果有传值则取传入的值,如果没有传值,则取上层的宏中的值!

    以上的例子中定义了名为:

    formatIncreaseData 和 renderTheme 的函数

    调用方式为:
    1 #renderTheme($fundGroup.renqiList)
    2 #renderTheme($fundGroup.zhutiList)

    所以,velocity的宏使Velocity作为一个同步的模板引擎的功能达到最大化!

  • 相关阅读:
    移动触摸事件之二
    移动touch事件之一
    Phonegap创建项目语法
    JS自定义去除字符串左右两边的指定字符
    video标签常用属性及说明
    html5开发之viewport使用
    页面事件总结
    缓存与预取
    修改JQM的默认配置属性
    JQM事件详解
  • 原文地址:https://www.cnblogs.com/sumbud/p/5777710.html
Copyright © 2020-2023  润新知