Jekyll如何自定义摘要
创始人
2024-03-22 13:38:32
0

最近搭建博客网站的时候遇到一个问题:博客的摘要包含了内容的格式,比如下面这张图。
请添加图片描述
标题的样式显示在摘要中,这可太奇怪了。我在查找文档之后没有想到合适的解决方案,于是乎就去 Jekyll 的项目下面提了个 Issue 问了一下。
请添加图片描述

在一个星期之后,得到了两个不错的解决思路,这里将解决方案分享给大家。

忽略摘要中的标签

第一个解决思路就是利用 Liquid 的strip_html,来过滤掉生成的摘要部分的全部 HTML 标签,这样自然就不会有文本样式出现在摘要中了。但是为了页面好看,不产生显示bug,最好在外部加一个

标签。如下:

{% for blog in site.blogs %}{% if blog.category == "SwiftUI" %}
  • { blog.url }}">{{ blog.title }}

    {{ blog.date | date: "%Y-%m-%d" }}

    {{ blog.excerpt | strip_html }}

  • {% endif %} {% endfor %}

    这样显示的效果就还可以,如下:
    请添加图片描述
    这个解决方案非常简单,博客文档本身也不需要额外的处理,唯一的问题就是,开头的“前言”二字如果没有可能更好看一些。这时候就感谢第二位提供的解决方案了。

    自定义摘要内容的开始位置

    Jekyll 生成摘要的时候是通过从文档开头开始判断\n\n,然后将第一个\n\n之前的的内容当作摘要。也就是说,Jekyll 通过判断博客文档中的第一个空行来生成摘要。但是我们可以通过一些简单的处理,来调整开始位置。这种方案就不用忽略所有标签,以及加上

    来保持样式了。

    首先在文档中,在我们想开头的地方加上,来表示摘要的开始,如下:
    请添加图片描述

    然后在页面文件中,将语句改成如下格式:

    {% for blog in site.blogs %}{% if blog.category == "SwiftUI" %}
  • { blog.url }}">{{ blog.title }}

    {{ blog.date | date: "%Y-%m-%d" }}

    {% assign excerptParts = blog.excerpt | split: "" %}{{ excerptParts[1] }}
  • {% endif %} {% endfor %}

    这时候显示效果如下:
    请添加图片描述
    这里就没有“前言”二字了,但是需要在每一个博客文档中加上分隔符,所以有点麻烦。

    小建议

    不过最好还是将二者一起使用,使用如下语句,这样可以不在摘要中显示样式和不显示不想显示的内容两个目的:

    {% for blog in site.blogs %}{% if blog.category == "SwiftUI" %}
  • { blog.url }}">{{ blog.title }}

    {{ blog.date | date: "%Y-%m-%d" }}

    {% assign excerptParts = blog.excerpt | split: "" %}

    {{ excerptParts[1] | strip_html }}

  • {% endif %} {% endfor %}

    希望能帮到有需要的人~

    相关内容

    热门资讯

    AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
    银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
    【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
    不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
    AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
    月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...
    ​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
    北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
    AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...
    AWR报告解读 WORKLOAD REPOSITORY PDB report (PDB snapshots) AW...