hexo链接持久化终极解决之道

  1. 背景
  2. 过时解决方案
  3. 终极方案
  4. 不建议的写法

背景

大家知道 hexo 默认的链接是 http://xxx.yy.com/2013/07/14/hello-world 这种类型的,这源于站点目录下的配置_config.yml 里的配置: permalink: :year/:month/:day/:title/. 这种默认配置的缺点就是一般文件名是中文,导致 url 链接里有中文出现,这会造成很多问题,如使用 gitment,也不利于 seo。另外就是年月日都会有分隔符。本文介绍经过作者研究总结出的最终解决方案。

过时解决方案

在 md 文件的 Front-matter 区域,增加一个 urlname 属性,用来放文章的英文名字。如下图所示:

title: hexo链接持久化终极解决之道
urlname: hexo_permalink
date: 2017-08-31 23:53:24
comments: true
categories:
- 综合
tags:
- hexo

然后修改_config.yml 里的配置:

permalink: posts/:category/:year:month:day-:urlname.html
permalink_defaults:
  urlname: index

后缀增加 .html 给人以静态页面感觉,利于 seo. 这里面:urlname 表示引用的这个变量。前面是分类/年月日。另外增加一个 urlname 这个属性的默认值,当md文档里不填这个属性,就用这个值。这里设的是 index,也就是说如果不填这个属性,其链接为: http://xxx.com/posts/uncategorized/20170828-index.html 。当然最好写上这个属性,偶尔某天不写这个属性也没关系。

另外还要解决一个问题,就是:category 分类有可能为中文。为此在站点下配置文件里设置:

default_category: uncategorized
category_map:
  综合: common

这样在 Front-matter 里,分类该写中文写中文,最终的链接会翻译成英文。

终极方案

无意中看到 http://muyunyun.cn/posts/f55182c5/#more ,最终决定采用这种方案使用hexo-abbrlink这个插件,猜测是根据时间点算出的最终链接,后期不管怎么修改永久链接都不会变.一来自己不用再增加什么属性了,也不用考虑分类中文化的问题。二来后面的层级更短,更利于SEO。(一般SEO只爬三层)

npm install hexo-abbrlink --save

站点配置文件里:

permalink: post/:abbrlink.html
abbrlink:
  alg: crc32  # 算法:crc16(default) and crc32
  rep: hex    # 进制:dec(default) and hex

另外可以修改 scaffolds 里的模版文件,修改post.md为:

---
title: {{ title }}
date: {{ date }}
comments: true
categories:
tags:
---

不建议的写法

有的人采用了 md 文件的名字是英文,在 Front-matter 里将 title 写成正常的中文呢,这个将来文章多了,都是英文不利于收藏整理。


转载请注明来源,欢迎对文章中的引用来源进行考证,欢迎指出任何有错误或不够清晰的表达。可以在下面评论区评论,也可以邮件至 1432803776@qq.com

文章标题:hexo链接持久化终极解决之道

字数:637

本文作者:AI悦创

发布时间:2021-03-11, 15:15:54

最后更新:2021-03-11, 15:27:02

原始链接:https://huangjiabaoaiyc.gitee.io/aiyc/19acb239.html

版权声明: "署名-非商用-相同方式共享 4.0" 转载请保留原文链接及作者。

×

喜欢就点赞,疼爱就打赏