Zope(ZPT)重叠标签

时间:2013-04-16 09:28:17

标签: html zope template-tal zpt template-metal

我尝试创建一个开放的div标记条件,并在Zope页面模板中使用TAL关闭另一个条件中的div标记,但我不允许重叠标记。

这是我的代码:

<div id="notaccordion">                                                                                      
    <tal:x repeat="item python:range(26)">                                                                                                                         
        <tal:x define="global block_name python:current.values()[0]['block_name']">         

            <tal:x condition="python:isDone">                                                                               
                </div>                                                                                  
            </tal:x>    

            <tal:x condition="python:not isDone">                                                                                     
                <tal:x replace="python:block_name">                                                                                                                                             
                </tal:x>                                                                                                       
                <div>                                                                                                                                                                                                                                                                                                                                         
            </tal:x>  

        </tal:x>                                                                     
     </tal:x>                                                                                                                              
 </div> 

重要的部分是:

            <tal:x condition="python:isDone">                                                                               
                </div>                                                                                  
            </tal:x>

这是错误。

Compilation failed
zope.tal.taldefs.TALError: TAL attributes on <tal:x> require explicit </tal:x>

我尝试使用Python脚本,但它也没有用。

<div id="notaccordion">                                                                                      
    <tal:x repeat="item python:range(26)">                                                                                                                         
        <tal:x define="global block_name python:current.values()[0]['block_name']">         

            <tal:x condition="python:isDone">                                                                               
                <tal:x content="python:context[close_div]()">
                </tal:x>                                                                                           
            </tal:x>    

            <tal:x condition="python:not isDone">
                <tal:x replace="python:block_name">                                                                                                                                                         
                </tal:x>                                                                                                       
                <tal:x content="python:context[open_div]()">
                </tal:x>                                                                                                                                                                                                                                                                                                                                                
            </tal:x>  

        </tal:x>                                                                     
    </tal:x>                                                                                                                              
</div> 

使用close_div脚本:

print '</div>'
return printed

它返回&lt;/div&gt;而不是</div>

如果你想知道我为什么要这样做。我有一个需要显示的树结构。由于我(我想)不能递归,我尝试使用LIFO列表来模拟它。 current是我当前的节点。

我尝试实现这一点(节点是dict的dict ...用作树):

lifo = list()
lifo.append([node, False])

while lifo:
    current, isDone = lifo[-1]
    block = current.keys()[0]
    if isDone:
        print '</div>'
        lifo.pop()
    else:
        lifo[-1][1] = True
        print '<div>'
        print block
        children = current[block].get('children', {})
        if children:
            for childBlock, childValue in children.items():
                lifo.append([{childBlock:childValue}, False])

感谢任何帮助或建议

1 个答案:

答案 0 :(得分:1)

页面模板必须是有效的XML,因此您不能随意包含标签。最好以递归方式处理树结构(可能使用宏代码段):

<metal:recurse define-macro="list">
  <ul>
    <li tal:repeat="el elements">
      <span tal:content="el/id">element id</span>
      <metal:block tal:condition="el/children"
                   tal:define="elements el/children">
        <div metal:use-macro="template/macros/list" />
      </metal:recurse>
    </li>
  </ul>
</metal:recurse>

例如,Plone导航portlet也为每个级别使用separate macro template,调用自身来呈现子级(recurse 是相同的模板)。

对于使用open_divclose_div脚本的特定方法,您需要mark the content value as structure以防止自动HTML转义发生:

<tal:x content="structure python:context[open_div]()">