Next主题_next3d桌面主题

Next主题_next3d桌面主题概述最近next6折腾了一段时间,最后还是回到了next5,但是添加阅读全文按钮以后,默认的摘要生成不太方便,于是就把注意打到了js上。这里整理一下next5生成摘要的方法。一、y

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

概述

最近 next6 折腾了一段时间,最后还是回到了 next5,但是添加阅读全文按钮以后,默认的摘要生成不太方便,于是就把注意打到了 js 上。

这里整理一下 next5 生成摘要的方法。

一、yaml

这个是 hexo 自带的,通过直接在 yaml 里面配置

---
title: next5主题自定义摘要
date: 2020-12-21
tags: [杂七乱八]
categories: [杂七乱八]
description: 这里是一段摘要
---

不过加完以后, next 会默认在文章详情页面的发布信息下也生成摘要,个人觉得不是很美观。

二、文章截断

这个是 next 自带的,可以通过在文章中插入:

<!-- more -->

在标签之前的部分会作为文章摘要展示,优点是文章详情页面不会再另外展示,比较没关,但是缺点是需要手动一个一个添加,有些老文章没有加摘要还需要手动添加,不太方便。

三、自动截断

在 hexo 的配置文件中添加如下配置:

auto_excerpt:
  enable: true
  length: 200

即可自动生成文章摘要。这种方式优点在于方便,但是长度不固定,而且因为带样式的缘故,可能页面会不是很协调。

在 next6 以后这种方式就不是默认支持的了,需要另外安装插件使用。

四、js 截取摘要

顾名思义,自己写 js 截断,这种方法和自动截断差不多,但是相对比较自由。个人比较习惯博客园那样不带样式的自动摘要,但是折腾来折腾去貌似都没弄出来这个效果于是决定用自己的渣渣 js 写一个。

首先根据渲染出来的页面,写好对应截取文本的 js:

getAbstract();

/**
 * 截取摘要
 */
function getAbstract() {
    let posts = document.getElementById('posts');

    if (document.getElementsByTagName('article').length <= 1) {
        console.log("不在主页!");
        return ;
    }

    let arts = posts.getElementsByClassName("post-body");
    for (let i = 0; i < arts.length; i++) {
        let dom = arts[i];
        let content = dom.innerText
            .substring(0, 250)  + "......";

        let readAll = dom.getElementsByClassName("post-button")[0];
        dom.innerHTML = content;
        dom.appendChild(readAll);
    }
}

该文件命名为 abstract.js,并且放在 themes\next\source\js\src下。

然后找到 \themes\next\layout目录下的 _layout.swig文件,会看到很多通过 include 语法引入的组件,拉到最底下,在 body 标签之前添加 script :

<!-- 引入目录截取js -->
<script type="text/javascript" src="/js/src/abstract.js"></script>

当然,这个也可以写在那些被 include 引入的组件里头,效果是一样的。

最后 hexo clean && hexo g && hexo s三连查看效果即可。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/170769.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 预防鼠标手

    预防鼠标手

    2021年8月7日
    49
  • android listview更新数据

    android listview更新数据要使listView的列表项发生改变时及时显示在UI中,就要更新listView的数据。两种方法:方法一:数据直接在adapter上修改,adapter.add().等方法方法二:本质上是listview绑定Adapter,Adapter关联List,因此List变化后导致Adapter同步变化;再通过调用adapter.notifyDataSetChanged();方法使得li

    2022年7月17日
    15
  • NVIC寄存器组

    NVIC寄存器组在STM32中用到了Cortex-M3定义的三组寄存器,有关这三组寄存器的说明不在STM32的技术手册中,需要参考ARM公司发布的Cortex-M3TechnicalReferenceManual(r2p0)。在STM32的固件库中定义了三个结构体与这三个寄存器组相对应,这三个结构体与ARM手册中寄存器的对应关系如下: 一、NVIC寄存器组STM32的固件库

    2022年5月12日
    74
  • python归一化函数_机器学习-归一化方法

    python归一化函数_机器学习-归一化方法1.归一化(Normalization)引入归一化,是由于在不同评价指标(特征指标)中,其量纲或是量纲单位往往不同,变化区间处于不同的数量级,若不进行归一化,可能导致某些指标被忽视,影响到数据分析的结果。为了消除特征数据之间的量纲影响,需要进行归一化处理,以解决特征指标之间的可比性。原始数据经过归一化处理后,各指标处于同一数量级,以便进行综合对比评价。1.必要性举例:以房价问题为例,假设我们…

    2022年10月11日
    3
  • android toast居中显示_android Toast 弹出在屏幕中间位置以及自定义Toast

    android toast居中显示_android Toast 弹出在屏幕中间位置以及自定义ToastToast我想我们应该使用的都很多,一般我们使用默认设置较多,但是默认设置往往不能满足我们的需求,那我们现在来自定义下:默认Toast:Toast.makeText(MainActivity.this,”点击按钮”,Toast.LENGTH_SHORT).show();设置Toast位置:通过setGravity设置Toast位置,可以是Gravity.CENTER:中间Gravity.BOTT…

    2025年11月3日
    0
  • JAVA读取csv文件_java读取csv文件某一列

    JAVA读取csv文件_java读取csv文件某一列csv文件的介绍以下是来自百度百科的介绍逗号分隔值(Comma-SeparatedValues,CSV,有时也称为字符分隔值,因为分隔字符也可以不是逗号),其文件以纯文本形式存储表格数据(数字和文本)。纯文本意味着该文件是一个字符序列,不含必须像二进制数字那样被解读的数据。CSV文件由任意数目的记录组成,记录间以某种换行符分隔;每条记录由字段组成,字段间的分隔符是其它字符或字符串,最常见的是逗号或制表符。通常,所有记录都有完全相同的字段序列。通常都是纯文本文件。建议使用WORDPAD或是记事本来

    2025年6月1日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号