简体   繁体   English

如何在Typo3中将菜单拆分为多个列?

[英]How do you split a menu into multiple columns in Typo3?

I have a node in Typo3 with a lot of pages in it which I would like to display as a menu in 4 columns. 我在Typo3中有一个节点,其中有很多页面,我希望将其显示为4列的菜单。 The sorting of the columns should be from left to right and then wrap around. 列的排序应从左到右,然后环绕。

Like this: 像这样:

Col1        Col2       Col3       Col4
 A            B          C          D
 E            F          G

In my solution (was done in Typo3 LTS 6.2 but should work with all current versions as well), I used this approach to achieve the columns. 在我的解决方案中(已在Typo3 LTS 6.2中完成,但也应与所有当前版本一起使用),我使用了这种方法来实现列。 Please note that the formatting is done with bootstrap in mind: 请注意,格式化是在考虑引导程序的情况下进行的:

# Menu with 4 columns
lib.columnMenu = COA
lib.columnMenu {

  10.wrap = <div class="col-sm-3"><ul> | </ul></div>
  10 = HMENU
  10.special = directory
  10.special.value = INSERT YOUR PAGE ID HERE

  10.1 = TMENU
  10.1.NO{
    allWrap=<li>|</li>

    stdWrap.if.isFalse.prioriCalc=1
    stdWrap.if.isFalse.cObject=TEXT
    stdWrap.if.isFalse.cObject.insertData=1
    stdWrap.if.isFalse.cObject.value=({register:count_HMENU_MENUOBJ}+3)%4

    allWrap.if.isFalse.cObject=TEXT
    allWrap.if.isFalse.prioriCalc=1
    allWrap.if.isFalse.cObject.insertData=1
    allWrap.if.isFalse.cObject.value=({register:count_HMENU_MENUOBJ}+3)%4
    }

  20 < .10
  20.wrap = <div class="col-sm-3"><ul> | </ul></div>

  20.1.NO{
    allWrap = <li>|</li>
    stdWrap.if.isFalse.cObject.value=({register:count_HMENU_MENUOBJ}+2)%4
    allWrap.if.isFalse.cObject.value=({register:count_HMENU_MENUOBJ}+2)%4
    }

  30 < .10
  30.wrap = <div class="col-sm-3"><ul> | </ul></div>

  30.1.NO{
    allWrap = <li>|</li>
    stdWrap.if.isFalse.cObject.value=({register:count_HMENU_MENUOBJ}+1)%4
    allWrap.if.isFalse.cObject.value=({register:count_HMENU_MENUOBJ}+1)%4
    }

  40 < .10
  40.wrap = <div class="col-sm-3"><ul> | </ul></div>

  40.1.NO{
    allWrap = <li>|</li>
    stdWrap.if.isFalse.cObject.value=({register:count_HMENU_MENUOBJ})%4
    allWrap.if.isFalse.cObject.value=({register:count_HMENU_MENUOBJ})%4
    }     
  }
}
# End Menu

Then you would just include the menu in some fluid template partial like this: 然后,您只需将菜单包含在部分可变模板中,如下所示:

<div class="row mb-20">
  <f:cObject typoscriptObjectPath="lib.columnMenu"/>
</div>

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM