4

他们有什么方法可以根据他们而不是一个一个地遍历列表项吗?我想以 1、3、5、7、9 和 2、4、6、8 的顺序遍历字段列表。我试过这样使用

<#list section.field as field>
 <div class="col1">
 ${field.@label}:<input type="text"/></div>
 <#if field_has_next>
 <div class="col2">
   ${field[field_index+1].@label}:<input type="text"/>
 </div>
 </#if>
</#list>

但这给了我错误。

4

1 回答 1

5

这就是?chunkhttp://freemarker.org/docs/ref_builtins_sequence.html#ref_builtin_chunk):

<#list section.field?chunk(2) as row>
  <#list row as field>
    <div class="col${field_index + 1}">
      ${field.@label}: <input type="text"/>
    </div>
  </#list>
</#list>

否则我不知道你的解决方案会出现什么错误,但肯定有一个错误,它显示所有字段,但最后一个字段两次。您可以使用类似的东西自由地使用索引

<#assign fields = section.field>
<#assign idx = 0>
<#list 0..999999 as _>
   <#if idx == fields?size><#break></#if>
   ... even column ...
   <#assign idx = idx + 1>

   <#if idx == fields?size><#break></#if>
   ... odd column ...
   <#assign idx = idx + 1>
</#list>
...

但正如您所见,它并不真正适合 FreeMarker(它非常冗长)。

于 2013-07-19T06:27:55.103 回答