drupal - Drupal 9 - 不显示消息和消息状态系统块
问题描述
感谢您花时间阅读我的问题。
我在使用 Drupal 9 在我的内容区域中添加消息和消息状态块时遇到问题。我使用的是自定义主题。
块根本不显示。它们甚至没有添加到 DOM 中。
这是我的块配置:https ://imgur.com/gPvEq1Q (对不起,它是法语。两个块用红色下划线)
以及每个区块的配置:https ://imgur.com/q3cBToL和https://imgur.com/hePdhHn(同样是法语,但对页面、角色或内容类型没有限制 - 它应该出现在任何地方)
我在网上找到了这些解决方案:
我尝试卸载我的主题,清除缓存,重新安装我的主题,但它不起作用。这些块也没有出现在 Bartik 主题中。
2 - https://www.drupal.org/forum/support/post-installation/2018-09-23/new-blocks-not-displaying
我尝试添加一个简单的测试块,它正常显示。
我尝试使用 $this->messenger()->addMessage("test"); 显示测试消息 在一个模块中确保有一些东西要显示但没有成功。
我不确定它是否有帮助,但这是我的 page.twig 模板:
<header aria-label="Site header" class="header" id="header" role="banner">
<div id='header-content'>
<div id="header-left">
{{ page.branding }}
{{ page.navigation }}
</div>
<div id='header-right'>
{{ page.user_menu }}
{{ page.search }}
</div>
</div>
</header>
<section class="main" id="main">
<main aria-label="Site main content" class="content" id="content" role="main">
{{ page.content }}
</main>
</section>
<footer aria-label="Site footer" class="footer" id="footer" role="contentinfo">
<div class="footer--top">
{{ page.footer_first }}
</div>
<div class="footer--bottom">
{{ page.footer_bottom }}
</div>
</footer>
你们中有人遇到过这个问题吗?有解决办法吗?
再次感谢 !
编辑
这是 twig debug 的输出:
<!-- THEME DEBUG -->
<!-- THEME HOOK: 'block' -->
<!-- FILE NAME SUGGESTIONS:
* block--messages.html.twig
x block--system-messages-block.html.twig
* block--system.html.twig
* block.html.twig
-->
<!-- BEGIN OUTPUT from 'core/modules/system/templates/block--system-messages-block.html.twig' -->
<div data-drupal-messages-fallback class="hidden"></div><span data-big-pipe-placeholder-id="callback=Drupal%5CCore%5CRender%5CElement%5CStatusMessages%3A%3ArenderMessages&args%5B0%5D&token=_HAdUpwWmet0TOTe2PSiJuMntExoshbm1kh2wQzzzAA"></span>
<!-- END OUTPUT from 'core/modules/system/templates/block--system-messages-block.html.twig' -->
这表明 \Drupal::messenger()->addMessage(); 不输出任何消息。
我注意到使用 FormBase 类进行测试的一件奇怪的事情是 Drupal\Core\Form\FormStateInterface::setErrorByName() 方法工作正常。正在显示一条消息,并且 twig 调试输出变为
<!-- THEME DEBUG -->
<!-- THEME HOOK: 'block' -->
<!-- FILE NAME SUGGESTIONS:
* block--cessoc-messages.html.twig
x block--system-messages-block.html.twig
* block--system.html.twig
* block.html.twig
-->
<!-- BEGIN OUTPUT from 'core/modules/system/templates/block--system-messages-block.html.twig' -->
<div data-drupal-messages-fallback class="hidden"></div>
<!-- THEME DEBUG -->
<!-- THEME HOOK: 'status_messages' -->
<!-- BEGIN OUTPUT from 'core/modules/system/templates/status-messages.html.twig' -->
<div data-drupal-messages>
<div role="contentinfo" aria-label="Message d'erreur">
<div role="alert">
<h2 class="visually-hidden">Message d'erreur</h2>
The title must be at least 5 characters long.
</div>
</div>
</div>
<!-- END OUTPUT from 'core/modules/system/templates/status-messages.html.twig' -->
<!-- END OUTPUT from 'core/modules/system/templates/block--system-messages-block.html.twig' -->
解决方案
我的问题解决了!
就像Kien Nguyen建议的那样,这是由 BigPipe 模块没有用状态消息填充消息块引起的问题。
显然,这是因为我的主题包含一个过时的 jQuery.js 文件。我删除了它,现在一切正常。
推荐阅读
- php - Appsync 的 graphql 订阅不适用于 PHP5
- angular - 角度 ts 文件中的 i18n $localize
- linux - 具有不同行大小的多个文件的平均值
- identityserver4 - Blazor 客户端 RemoteAuthenticatorView
- c# - 在为其分配新值之前清除非空集合
- powershell - 不断收到错误“不包含名为'Trim'的方法。使用简单的Trim命令时-我的代码有什么问题?
- r - 获取特定列的所有可能组合,同时保留其他列
- flutter - 如何在颤动的命名路由中传递多个参数
- java - 如何添加 Quartz JobListener
- javascript - x 秒后 Console.log 记录每个数组值