参考文章:

Freemarker自定义标签的简单分析

定义一个基本的文本框:传入参数为:resourceName idName resourceVal="" idVal="" classVal="",其中resourceName ,idName为必填, resourceVal="" idVal="" classVal="" 分别为选填,其中必填都作为空间的 name,选填的都作为结果值,具体的见代码:

html中 macro自定义如下:

<#macro txtResource resourceName idName  resourceVal="" idVal="" classVal="">
<input type="text" name="${resourceName}" value="${(resourceVal)!}" class="${(classVal)!}" readonly="readonly"
style="cursor:pointer" /> &nbsp;<a class="xm_ablue" href="javascript:clearDicTree('${resourceName}','${idName}')">清空</a>
<input type="hidden" name="${idName}" value="${(idVal)!}"/>
<#-- 绑定输点击清空时的事件-->
<script>
function clearDicTree(resourceName,idName)
{
$("input[name='"+resourceName+"']").val('');
$("input[name='"+idName+"']").val('');
}
</script>
</#macro>

调用macro 控件:

<@txtResource resourceName="parentName" idName="parentId" resourceVal="张三" idVal="1" classVal="icon2"/>

界面展示效果

点击“清空”按钮,则清空文本框中的内容;点击文本框中js也可以写在控件定义的 html中

3.freemark中遍历Map:typeMap,todoMap 都是map,他们的key相同

<#if typeMap?exists>
       <#list typeMap?keys as key>
         <tr>
         <td colspan="4">
         <table width="100%" border="0" cellspacing="0" cellpadding="0" class="s_todoin">
             <#assign type = typeMap[key] />
             <tr>
             <th colspan="4"><div class="s_todotit s_todotitup" name="div_${type.businessCode}" onclick="javascript:clickTodoType('${type.businessCode}');">${type.name}</div></th>
             </tr>
              <#if todoMap?exists>
              <#assign todoList =todoMap[key] />
              <#list todoList as item>
               <tr name="tr_${type.businessCode}">
                 <td width="49%" class="s_todotd"><a href="${item.refUrl!}" target="_blank" title="${item.sheetTitle!}"><#if item.sheetTitle?? && ""!=item.sheetTitle>${item.sheetTitle}<#else>未知标题</#if></a></td>
                 <td width="15%">${item.nodeName}</td>
                 <td width="12%">${item.createUserName}</td>
                 <td width="24%" >${item.createTime['time']}</td>
               </tr>
               </#list>
               </#if>
         </table>
         </td>
         </tr>
       </#list>
     </#if>

4.freemark中遍历多维数组;

<#list oftenList as firstMenu>
   <div class="modle_usualcbw" name="often">
    <div class="modle_usualtcb" name="module">
      <input type="checkbox" value="${firstMenu.menuId}" <#if firstMenu.url?? && ""!=firstMenu.url>name="hasurl"</#if>  <#if firstMenu.userId??>checked="checked"</#if>/>${firstMenu.name}
    </div>
      <#if firstMenu.children?? && (firstMenu.children?size>0)>
                   <#assign secondMenus=firstMenu.children>
    <div class="modle_usualtcb2ws">
   
                   <#list secondMenus as secondMenu>
     <div class="modle_usualtcb2w" name="menu">
      <div class="modle_usualtcb2" name="secondMenu">
              <input type="checkbox" value="${secondMenu.menuId}" <#if secondMenu.url?? && ""!=secondMenu.url>name="hasurl"</#if> <#if secondMenu.userId??>checked="checked"</#if>/>${secondMenu.name}
       </div>
        <#if secondMenu.children?? && (secondMenu.children?size>0)>
         <#assign thirdMenus=secondMenu.children>
          <div class="modle_usualcb" name="thirdMenu">
           <ul>
           <#list thirdMenus as thirdMenu>
            <li>
              <input type="checkbox" value="${thirdMenu.menuId}" <#if thirdMenu.url?? && ""!=thirdMenu.url>name="hasurl"</#if>  <#if thirdMenu.userId??>checked="checked"</#if>/>${thirdMenu.name}
             </li>
           </#list>
           </ul>
          </div>
        </#if>
     </div>
     </#list>
    
    </div>
     </#if>
    
   </div>
 </#list>

5.freemark中数字和字符的格式:保留小数点后2位

<input  name='currentcost' value='#{(project.progress?default(0))*(project.budgetContractA?default(0))/100;M2}' readonly='readonly'>

具体见:http://talentkep.iteye.com/blog/510756

用freemarker定义宏实现自定义公用控件的更多相关文章

  1. Android Studio自定义组合控件

    在Android的开发中,为了能够服用代码,会把有一定共有特点的控件组合在一起定义成一个自定义组合控件. 本文就详细讲述这一过程.虽然这样的View的组合有一个粒度的问题.粒度太大了无法复用,粒度太小 ...

  2. 安卓自定义组合控件--toolbar

    最近在学习安卓APP的开发,用到了toolbar这个控件, 最开始使用时include layout这种方法,不过感觉封装性不好,就又改成了自定义组合控件的方式. 使用的工具为android stud ...

  3. Android自定义控件之自定义组合控件

    前言: 前两篇介绍了自定义控件的基础原理Android自定义控件之基本原理(一).自定义属性Android自定义控件之自定义属性(二).今天重点介绍一下如何通过自定义组合控件来提高布局的复用,降低开发 ...

  4. C# DataGridView自定义分页控件

    好些日子不仔细写C#代码了,现在主要是Java项目,C#.Net相关项目不多了,有点手生了,以下代码不足之处望各位提出建议和批评. 近日闲来无事想研究一下自定义控件,虽然之前也看过,那也仅限于皮毛,粗 ...

  5. 自定义圆形控件 RoundImageView

    1.自定义圆形控件 RoundImageView package com.ronye.CustomView; import android.content.Context; import androi ...

  6. 自定义圆形控件RoundImageView并认识一下attr.xml

    今天我们来讲一下有关自定义控件的问题,今天讲的这篇是从布局自定义开始的,难度不大,一看就明白,估计有的同学或者开发者看了说,这种方式多此一举,但是小编我不这么认为,多一种解决方式,就多一种举一反三的学 ...

  7. DuiLib 自定义识别控件

    遇到一个断点无法识别自定义的控件,运气比较好,一搜就搜出来了: 参考地址:http://www.bkjia.com/ASPjc/992050.html 主要是这个函数: CControlUI* CDi ...

  8. iOS开发UI篇—Quartz2D(自定义UIImageView控件)

    iOS开发UI篇—Quartz2D(自定义UIImageView控件) 一.实现思路 Quartz2D最大的用途在于自定义View(自定义UI控件),当系统的View不能满足我们使用需求的时候,自定义 ...

  9. (九)ASP.NET自定义用户控件(2)

    http://www.cnblogs.com/SkySoot/archive/2012/09/04/2670678.html 用户控件 在 .NET 里,可以通过两种方式把自己的控件插入到 Web 窗 ...

随机推荐

  1. ccs3

    [ 布局 Layout] display:none | intel |block | list-item | inline-block| [ 取值:] onne:隐藏对象.与visibility属性的 ...

  2. seajs封装js方法

    必须要先引入sea.js文件 <script src="js/sea.js"></script> 其次,引入其他js文件 <script> se ...

  3. Memcache所有方法及参数详解

    memcache函数所有的方法列表如下: 参考http://www.php.net/manual/zh/function.Memcache-add.php Memcache::add - 添加一个值, ...

  4. WCF 部署在Windows 2012 IIS上各种报错的解决方法

    1.由于扩展配置问题而无法提供您请求的页面.如果该页面是脚本 ,请添加处理程序.如果勇载文件,请添加 MIME 映射. 以管理员身份,在cmd中运行C:\Windows\Microsoft.NET\F ...

  5. PowerDesigner中Name与Code同步的问题

    转自:http://blog.sina.com.cn/u/48932504010005t9 PowerDesigner中,但修改了某个字段的name,其code也跟着修改,这个问题很讨厌,因为一般来说 ...

  6. android 保存文件的各种目录列表

    一般的,我们可以通过context和Environment来获取要保存文件的目录 ($rootDir) +- /data -> Environment.getDataDirectory() | ...

  7. RSA不限长度非对称加密解密C#

    RSA 分段加解密[解决“不正确的长度”的异常] RSA 是常用的非对称加密算法.最近使用时却出现了“不正确的长度”的异常,研究发现是由于待加密的数据超长所致. .NET Framework 中提供的 ...

  8. C语言中内存的申请函数

    C语言跟内存申请相关的函数主要有 alloca,calloc,malloc,free,realloc,sbrk等. alloca是向栈申请内存,因此无需释放. malloc分配的内存是位于堆中的,并且 ...

  9. 零基础如何自学MySQL数据库?

    作者:姜健链接:https://www.zhihu.com/question/34840297/answer/67536521来源:知乎著作权归作者所有,转载请联系作者获得授权. 本人是个活生生的例子 ...

  10. Linux跨服务器拷贝文件详解

    要实现跨服务器拷贝文件,只需执行以下命令就可以: scp /temp/FastDFS_v3..tar.gz root@ip:/temp 拷文件夹如下: scp -r /webapps/xxx root ...