
本教程详细介绍了如何在drupal区块标题旁添加一个功能性的“更多”链接,以满足常见的内容导航需求。文章强调通过修改区块模板(drupal 9+使用twig,drupal 7使用php)是实现此功能的最佳实践,而非依赖css伪元素,因其无法创建可交互的链接。教程提供了详细的代码示例,并涵盖了模板查找、实现步骤及相关注意事项,旨在帮助开发者高效、专业地扩展drupal区块功能。
在Drupal网站开发中,我们经常需要在区块(Block)标题旁边添加一个指向更多内容的链接,例如“更多新闻”、“查看全部”等。直接使用CSS的::after伪元素虽然可以添加文本或图标,但无法为其赋予可点击的超链接功能。实现这一需求的正确且推荐的方法是直接修改区块的模板文件。本教程将详细介绍如何在Drupal 7和Drupal 9+版本中通过模板重写来添加此类链接。
理解区块模板
Drupal的区块系统允许主题通过模板文件来控制区块的渲染方式。当需要改变区块的HTML结构或添加额外元素时,最佳实践是创建或修改主题中的区块模板文件。
1. 查找正确的区块模板
在进行模板修改之前,首先需要确定要修改的区块对应的模板文件。
启用模板建议(Theme Debugging): 这是查找模板文件最有效的方法。
Drupal 9+: 在 settings.local.php 文件中(通常位于 sites/default 目录下,需要复制 default.settings.local.php 并重命名),将 twig_debug 设置为 true:
$settings['twig_debug'] = TRUE;
清除缓存后,检查页面的HTML源代码,你会在区块的HTML注释中看到一系列模板建议,例如 block–system-menu-block–main.html.twig 或 block–views-block–news-block-1.html.twig。
Drupal 7: 在 settings.php 文件中,将 $conf[‘theme_debug’] = TRUE; 添加到文件末尾。清除缓存后,检查HTML源代码,同样会看到类似的模板建议注释。
创建自定义模板: 找到最具体的模板建议后,将其复制到你的主题(或子主题)的 templates 目录下,并重命名为该建议的文件名(例如,block–my-custom-block-id.html.twig 或 block–my-custom-block-id.tpl.php)。如果只是想修改所有区块的标题,可以使用更通用的 block.html.twig 或 block.tpl.php。
在Drupal 9+ (Twig) 中添加链接
对于Drupal 9及更高版本,区块模板使用Twig语法。
示例代码:
假设你找到了 block–your-block-id.html.twig 或决定修改 block.html.twig,请在其中找到渲染标题的部分,通常是包含
标签的代码块。
{# templates/block/block--your-block-id.html.twig #}{% if label %} {{ label }}
更多新闻{% endif %}{# 其他区块内容渲染,例如: {{ content }}#}
{{ label }}
更多新闻{% endif %}{# 其他区块内容渲染,例如:代码解释:
{% if label %}:检查区块是否有标题。
{{ label }}
:这是Drupal渲染区块标题的标准方式。title_attributes 允许你添加额外的HTML属性和CSS类。更多新闻:这是我们添加的“更多新闻”链接。href=”#”:这里使用了占位符。在实际应用中,你需要将其替换为指向具体内容页面的URL。这可以是硬编码的URL,也可以是动态生成的路径(例如,通过 path(‘view.news_page’) 或从区块配置中获取)。class=”more-link”:为链接添加一个CSS类,方便后续进行样式美化。
完成修改后,保存文件并清除Drupal缓存。
小羊标书
一键生成百页标书,让投标更简单高效
62 查看详情
在Drupal 7 (PHP) 中添加链接
对于Drupal 7版本,区块模板使用PHP语法。
示例代码:
假设你找到了 block–your-block-id.tpl.php 或决定修改 block.tpl.php,请在其中找到渲染标题的部分。
<div>subject): ?> <h2>subject; ?> 更多新闻 <div>
微信扫一扫
支付宝扫一扫