博客文章编辑发布指南
概述
博客采用静态hexo框架,基于node js,文章使用markdown语言进行编写。源文件保存于github仓库,使用git进行源码管理,使用github action自动化部署到远程服务器,并使用nginx提供对外服务。
编辑权限
可以私信我或发邮件申请仓库编辑权限,或者直接在github仓库发起合并请求
新建和编辑文章
git clone
下载github仓库源代码到本地- 编辑文件内容或使用
hexo new [name]
新建一个web链接为name的文章,新建的文章保存为/hexo/source/[year]/[name].md
,即可在其中使用markdown语言编写文章 - 提交你的更改并同步到github仓库
- github action自动进行网站内容的生成和部署,等待三五分钟左右即可打开网站查看更改。如果
build
出现报错err: Error: ENOENT: no such file or directory, open './search.xml'
请直接重试,仍然报错基本上markdown语法错误,请再次检查你的更改
文章配置
1 | --- |
新建的文章文件就包含上面的内容:
- title:文章标题,默认为设置的文章链接,可以修改为其他文字,可以为中文
- tags:文章标签,可以参考标签页已有的进行设置,也可以新建自己的。如果不想设置请直接删除这一配置项
- cover:文章封面图。文章封面图片统一保存于
hexo/source/img/
内 - categories:文章分类,设置方法类似tag
- data:文件新建时间,自动生成。主页文章排序依靠时间,修改为较大的值可用于置顶文章,但是一般不建议设置置顶
- description:简介描述。随便写两句话介绍一下就好。建议在此处加入文章作者信息(如果不是Triority本人编辑的话)
编辑完成应该类似这样,以本篇文章为例:
1 | --- |
不需要的配置项记得删除,比如你不想写description就把这一行全都删掉,否则文件生成会报错。
如果你添加了新的categories,请编辑模板文件加上你新增的分类字符串,模板文件位于/hexo/scaffolds/post.md
内容编辑
markdown
markdown语言语法请自行学习,初期使用不熟练推荐使用开源项目:Editor.md
资源文件路径
新建文章时,除了文章的文本文件/hexo/source/[year]/[name].md
同时还会新建/hexo/source/[year]/[name]
文件夹,对于在文章中使用的文件,均应保存在此处,包括图片,文件等内容。调用时直接使用文件名即可。
例如文章中添加的图片![](img.img)
,图片img.img
直接保存在上述文件夹即可,文件同理
标签外挂等特殊语法
这里只说一些常用的,因为标签外挂语法太多了,参见文档
插入图片
1 | //使用插件的语法 |
插入视频
1 | {% dplayer "url=wwww.xxx.cn/xxx.mp4" %} |
站内跳转
虽然可以直接使用markdown超链接直接跳转,但是不建议这样做。因为一旦更改了域名所有文章内的链接都将失效。建议使用post_link
标签。官方文档
1 | {% post_link filename [title] [escape] %} |
这样就会跳转到文件名为filename.md
的文章,并显示标题为[title]
。
1 | {% post_link CQWWRTTY2024 'RTTY竞赛' %} |
并排的图片
并排图片一般使用表格来表示格式
1 | | ![](1.png) | ![](2.png) | ![](3.png) | |
如果图片宽度不一致可能导致看起来很奇怪,如果不想手动改变图片尺寸,可以直接在表格新增一行相同的超级长的假图片,就可以让表格均分宽度
1 | | ![](1.png) | ![](2.png) | ![](3.png) | |
文件下载链接
1 | [文字](xxx.zip) |
哔哩哔哩视频
需要替换的内容:src
1 | {% raw %} |
特殊提示
DANGER!!!
1 | {% note danger modern %} |
折叠代码
来点击我
于是我就被展开啦1 | <details> |
小黑块
这是什么?哦原来 这是一个小黑块 哦!
1 | {% spoiler 被遮挡文字 %} |
文件生成和git提交
文章编辑完成之后,在/hexo
目录打开终端,输入hexo g
进行html文件生成,如果报错请检查文章内是否有语法错误,特别是文章配置部分。
如果报错为以下内容,无需理会重新执行hexo g
就好
1 | errno: -2, |
然后进行git提交和推送。别忘记这一步,git已经拯救了好几次这个博客