如何在 Drupal 8 中自定义/样式/主题自定义内容类型的输出?

Posted

技术标签:

【中文标题】如何在 Drupal 8 中自定义/样式/主题自定义内容类型的输出?【英文标题】:How to customize/style/theme the output of a custom content type in Drupal 8? 【发布时间】:2019-03-23 02:50:51 【问题描述】:

我正在创建自己的 Drupal 8 “经典”子主题。现在我用一些文本字段创建了一个名为“s-box”的内容类型。我还创建了一个名为“scol”的视图,它是一个“s-box”列表。这个“scol”作为一个块添加到站点的侧边栏中。

效果很好(这意味着所有内容都已显示),但我希望某些内容类型字段嵌套在特定标记中(如 h4 中的标题)。最好,我想为此内容类型“s-box”自定义整个输出。

但我想不通,树枝应该叫什么名字。到目前为止,我尝试过:

node--s-box.html.twig (what I thought would be the correct name)  
block--scol.html.twig  
field--node--s-box.html.twig  
field--s-box.html.twig  
node--scol.html.twig  
scol--s-box.html.twig

完美的解决方案是一个模板,我可以在其中构建自己的 html 并分配内容类型的字段。

【问题讨论】:

【参考方案1】:

只需启用 Twig 调试。见Debugging Twig templates。启用 Twig Debugging 后,您将获得作为 HTML cmets 直接打印到您的标记中的模板命名建议。在那里你会看到这个模板应该如何被准确命名。


您的sites/development.services.yml 应该如下所示:

# Local development services.
#
# To activate this feature, follow the instructions at the top of the
# 'example.settings.local.php' file, which sits next to this file.
parameters:
  http.response.debug_cacheability_headers: true
  twig.config:
      debug: true
      auto_reload: true
      cache: false
services:
  cache.backend.null:
    class: Drupal\Core\Cache\NullBackendFactory

您需要将以下行添加到您的settings.phpsettings.local.php

/**
 * Enable local development services.
 */
$settings['container_yamls'][] = DRUPAL_ROOT . '/sites/development.services.yml';

最终会给你类似的东西:

<!-- FILE NAME SUGGESTIONS:
   * node--page--j1.html.twig
   * node--1--full.html.twig
   * node--1.html.twig
   * node--page--full.html.twig
   * node--page.html.twig
   * node--full.html.twig
   x node.html.twig
-->

别忘了清除缓存!多次。

【讨论】:

谢谢!我已经启用了此功能,但现在您再次指出这一点,我找到了解决方案。我没有注意到我可以访问“views-view-fields.html.twig”中的所有字段。【参考方案2】:

解决办法是:

由于我的内容类型在视图中,我可以访问 views-view-fields--[my-view].html.twig 中的所有字段(在我的情况下:views-view-fields--scol.html.twig

键是fields 数组。我可以通过机器名称访问所有字段。喜欢fields.title.contentfields.field_foo.content

因此我可以在此处设置 s-box 的整个输出样式。

【讨论】:

以上是关于如何在 Drupal 8 中自定义/样式/主题自定义内容类型的输出?的主要内容,如果未能解决你的问题,请参考以下文章

如何在 Drupal 视图块中自定义 HTML 结构

ionic4中自定义主题的颜色

当自定义模板已应用于节点的内容类型时,如何在 Drupal 6 中自定义特定节点?

Drupal 视图中自定义表记录项的编辑链接

在QtQuick中自定义样式[重复]

Drupal 8 自定义模块“找不到主题挂钩”