• Jekyll如何自定义摘要


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

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

    忽略摘要中的标签

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

    标签。如下:

    {% for blog in site.blogs %}
        {% if blog.category == "SwiftUI" %}
            <li>
                <h2><a class="blog" href="{{ blog.url }}">{{ blog.title }}a>h2>
                <p class="info">{{ blog.date | date: "%Y-%m-%d" }}p>
                
                <p>{{ blog.excerpt | strip_html }}p>
            li>
        {% endif %}
    {% endfor %}
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

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

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

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

    来保持样式了。

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

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

    {% for blog in site.blogs %}
        {% if blog.category == "SwiftUI" %}
            <li>
                <h2><a class="blog" href="{{ blog.url }}">{{ blog.title }}a>h2>
                <p class="info">{{ blog.date | date: "%Y-%m-%d" }}p>
                
                {% assign excerptParts = blog.excerpt | split: "" %}
                
                {{ excerptParts[1] }}
            li>
        {% endif %}
    {% endfor %}
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

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

    小建议

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

    {% for blog in site.blogs %}
        {% if blog.category == "SwiftUI" %}
            <li>
                <h2><a class="blog" href="{{ blog.url }}">{{ blog.title }}a>h2>
                <p class="info">{{ blog.date | date: "%Y-%m-%d" }}p>
                {% assign excerptParts = blog.excerpt | split: "" %}
                <p>{{ excerptParts[1] | strip_html }}p>
            li>
        {% endif %}
    {% endfor %}
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    希望能帮到有需要的人~

  • 相关阅读:
    [开源工具]git stash clear后如何按时间顺序找回 比git fsck --lost-found好用1W倍
    List.of()的坑——不能够序列化
    开放之光——湖北电大搜题助力学习之旅
    为了摆脱 Android ,亚马逊开发基于Linux的操作系统
    浅谈放大器交调失真对系统的影响
    Java - 手写识别; 如何用spring ai和大模型做手写识别教程
    049:vue+openlayers鼠标pointermove显示城市名片(示例代码)
    SpringBoot未授权访问漏洞利用方法
    java的Timer全网最详细总结
    【国标语音对讲】EasyCVR视频汇聚平台海康/大华/宇视摄像头GB28181语音对讲配置
  • 原文地址:https://blog.csdn.net/qq_33919450/article/details/128201180