繁体   English   中英

Typo3 中的 TMENU - 从上面的级别插入 url

[英]TMENU in Typo3 - insert url from level above

我有一个TMENU ,在该菜单中,我想将“Level 1”中的 URL 插入到“Level 2”中的wrap项目中。

当前的 TypoScript 看起来像这样:

10 = HMENU
10 {
    1 = TMENU
    1 {
        expAll = 1

        NO = 1
        NO.allWrap = <li>|</li>
        NO.allWrap.insertData = 1
        NO.ATagTitle.field = abstract // description // title
    }

    2 = TMENU
    2 {
        expAll = 1
        stdWrap.wrap = <ul><li><a href="*****URL FROM LEVEL 1 SHOULD BE HERE*****"></a></li>|</ul>

        NO = 1
        NO.allWrap = <li>|</li>
        NO.allWrap.insertData = 1
        NO.ATagTitle.field = abstract // description // title
    }
}

任何提示? 感谢您的帮助!

stdWrap属性按定义的顺序执行(如文档中所示),请参阅https://docs.typo3.org/m/typo3/reference-typoscript/master/en-us/Functions/Stdwrap.html#prepend

知道在wrap3之前执行prepend可以解决这个挑战。

page = PAGE
page.10 = HMENU
page.10 {
    1 = TMENU
    1 {
        expAll = 1
        NO = 1
        NO.allWrap = <li>|</li>
        NO.allWrap.insertData = 1
        NO.ATagTitle.field = abstract // description // title
    }

    2 = TMENU
    2 {
        expAll = 1
        stdWrap.prepend = TEXT
        stdWrap.prepend {
          # remove `value` if page title shall be used
          value = URL from Level 1
          # using <current-page>.pid value pointing to previous level
          typolink.parameter.field = pid
          wrap = <li>|</li>
        }
        # `wrap3` is executed after `prepend`
        stdWrap.wrap3 = <ul>|</ul>

        NO = 1
        NO.allWrap = <li>|</li>
        NO.allWrap.insertData = 1
        NO.ATagTitle.field = abstract // description // title
    }
}

在这样的页面树上

+- A
|  +- AA
|  +- AB
|
+- B
   +- BA
   +- BB

呈现的 HTML 结果如下所示

<li><a href="/ts/a" title="A">A</a></li>
<ul>
  <li><a href="/ts/a">URL from Level 1</a></li>
  <li><a href="/ts/a/aa" title="AA">AA</a></li>
  <li><a href="/ts/a/ab" title="AB">AB</a></li>
</ul>

<li><a href="/ts/b" title="B">B</a></li>
<ul>
  <li><a href="/ts/b">URL from Level 1</a></li>
  <li><a href="/ts/b/ba" title="BA">BA</a></li>
  <li><a href="/ts/b/bb" title="BB">BB</a></li>
</ul>

更新自定义渲染替换静态value属性

除了使用属性stdWrap.prepend.value (如上例所示),也可以使用其他cObject指令 - 在这种情况下,例如RECORDS (参见https://docs.typo3.org/m/typo3/reference- Typscript/master/en-us/ContentObjects/Records/Index.html )

以下示例呈现父页面的字段nav_title (如果未将title定义为后备)。

page.10 {
    # ...
    2 {
        # ...
        stdWrap.prepend {
            # using `cObject` instead of `value`
            cObject = RECORDS
            cObject {
                tables = pages
                source.field = pid
                # rendering definition for retrieved record of table pages
                conf.pages = TEXT
                # `//` is used as fallback delimiter here, NOT as comment
                conf.pages.field = nav_title // title
            }
            # ...

暂无
暂无

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

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