前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Next主题_next3d桌面主题

Next主题_next3d桌面主题

作者头像
全栈程序员站长
发布2022-09-23 18:33:32
3860
发布2022-09-23 18:33:32
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。

概述

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

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

一、yaml

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

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

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

二、文章截断

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

代码语言:javascript
复制
<!-- more -->

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

三、自动截断

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

代码语言:javascript
复制
auto_excerpt:
  enable: true
  length: 200

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

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

四、js 截取摘要

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

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

代码语言:javascript
复制
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 :

代码语言:javascript
复制
<!-- 引入目录截取js -->
<script type="text/javascript" src="/js/src/abstract.js"></script>

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

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

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

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 概述
  • 一、yaml
  • 二、文章截断
  • 三、自动截断
  • 四、js 截取摘要
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档