开发者

Freemarker中的3种循环模式

目录
  • Freemarker 3种循环模式
    • 1. map循环
    • 2. list循环
    • 3. 自定义次数循环
  • Freemarker 循环遍历数字
    • 总结

      Freemarker 3种循ZTWhWcw环模式

      1. map循环

      举例:

      <#if vo.urlMap??>
       <#list vo.urlMap?keys as key>
        <li>
         <a href="${vo.urlMap[key]!''}" rel="external n编程ofollow" >${key!''}</a>
        </li>
       </#list>
      </#if>
      • vo.urlMap?keys: 将map中的key循环(类似keySet迭代器)
      • 循环中通过map[key]来取的key对应的valu编程客栈e
      • 如果需要当前循环下标, 使用循环对象_index取即可, 如: key_index

      2. list循环

      举例:

      <#list vo.valueList as value>
       <td>${value!''}</td>
      </#list>

      3. 自定义次数循环

      举例:

      <!-- 动态长度 -->
      <#list 0..(nums?number)!0 as i>
       <td>${vo.valueList[i]!''}</td>
      </#list>
      
      <!-- 固定长度 -->
      <#list 1..100 as i>
       <td>${vo.valueList[i]!''}</td>
      </#list>
      

      用于配合取出list中的元素(list长度有时少于预期, 所以自定义次数)

      需要注意的是, 由于循环次数和list长度解耦了, 要小心数组越界,

      (可以通过默认值的方式避免)

      如: ${(vo.valueList[i])!'无'}

      将前面整个用括号括起来会自动判定每一步是否为null

      Freemarker 循环遍历数字

      普通的循环遍历是这样:

      <#list recordPage.content as record>
      <!--do someting-php->
      </#list>

      要是遍历数字呢?可以这样: max 是传来的值。

      <#list 1..max as i>    
        <li><a href="#" rel="external nofollow" >${i}</a></li>
      </#list>

      但是如果这样写 -->     <#list 1..${max} as i>   Freemaker会报语法错误。

      当时我的需求是要写一个双层<#list>  外层list遍历对象,内层list需要对象的一个数量属性值来决定这个对象再次遍历几次。

      那上面代码中的max怎么赋值呢,试验了各种情况,只要<#list 1..${max} as i>遍历数字时出现‘${}’,就会报错。所以就试验了下不带 ${} 会出现什么样的情况,开发者_C开发于是出现了下面的代码:

      <#list allocationCars as allocationCar>
          <#list 1..(allocationCar.qty) as i>
              <td>${allocationCar_index+1} . ${i_index}</td>
            </#list>
      </#list>

      成功完成需求!

      allocationCars 是后台传来的car对象集合,一般我们使用<#list>遍历后会用  “ defValue="${(allocationCar.brandId?c)!}"  ”这种方式来获取遍历后对象的属性。

      但是又由于<#list>遍历数字时候得语法限制,给max赋值的地方无法使用 ‘${}’ 。而经过上面的实验得知,在<#list> 标签中获取对象的属性是不需要加javascript‘${}’的,可以直接获取到,看来应该是freemaker的内部机制进行了处理。

      总结

      以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

      0

      上一篇:

      下一篇:

      精彩评论

      暂无评论...
      验证码 换一张
      取 消

      最新开发

      开发排行榜