个性化阅读
专注于IT技术分析

将第二个自定义菜单添加到全局上下文时出现的问题

Issue when adding second custom menu to global context - Unsupported operand types in /app/wp-content/plugins/timber-library/vendor/twig/twig/lib/Twig/Environment.php(462)

我正在抓取第二个注册菜单, 并将其添加到标题模板中。我正在将Timber插件与Twig模板一起使用。

我将第二个菜单添加到全局上下文中:

$context['custom-menu'] = new Timber\Menu( 'Custom Menu' );

并在我的index.php文件中调用菜单。

$context = Timber::get_context();
$context['posts'] = new Timber\PostQuery();
$templates = array( 'index.twig' );
if ( is_home() ) {
    array_unshift( $templates, 'home.twig' );
}
Timber::render( $templates, $context );

header.twig文件包含在base.twig中, 该文件已扩展为index.twig。这包括所有标题。

{% include "partial/user-menu.twig" with {'custom-menu': custom-menu.get_items} %}
{% include "menu.twig" with {'menu': menu.get_items} %}
{% include "partial/sl_logo.twig" %}
{% include "partial/sl_search.twig" %}

menu.twig呈现得很好, 但是当我添加用户菜单时, 它在顶部出现了错误。当我使用{‘custom-menu’:custom-menu.get_items}删除时, 出现以下错误:Timber \ Menu类的对象无法转换为int

user-menu.twig文件如下所示:

    <ul>
    {% for item in custom-menu %}
        <li class="{{ item.classes | join(' ') }}">
            <a target="{{ item.target }}" href="{{ item.link }}">{{ item.title }}</a>
             {% include "user-menu.twig" with {'custom-menu': item.get_children} %}
        </li>
    {% endfor %}
    </ul>

Timber Github存储库上的文档建议你可以将菜单添加到全局上下文, 并在get_context时简单地添加菜单。

https://github.com/timber/timber/blob/master/docs/guides/menus.md

谁能帮助诊断问题?


#1


也许我会先在相同的情况下为你提供我正在使用的产品。

在functions.php中添加

function add_to_context( $data ){
    //menu
    $data['menu_primary'] = new TimberMenu( 'primary' );
    $data['menu_footer'] = new TimberMenu( 'footer' );
    return $data;
}

下次在所需位置使用:

{% for item in menu_primary.get_items %}
...
{% endfor %}
赞(0)
未经允许不得转载:srcmini » 将第二个自定义菜单添加到全局上下文时出现的问题

评论 抢沙发

评论前必须登录!