12.Hexo helpers类似函数和data folder数据文件夹

helper

Hexo里的helper,或者说是函数

基本上就是小函数,可以在layout布局中使用,可以允许做一些事情

如字符串操作、检查true或false、检查是否在一个页面上、打印出某个页面中的日期或时间特定格式

打开index.ejs

trim

可以通过

复制代码
<%-  %>

来访问helpers

在中间输入想要输入的helper的名称

复制代码
<%- trim %>

修剪前面的空白,字符串的尾随空格

复制代码
<%- trim("   This is my string   ")%>

这个字符串前后都有空格

在浏览器中渲染的时候,空格就消失了

titlecase

控制字符串中的大小写,将字符串中的每个单词大写

复制代码
<%- titlecase("This is my string")%>

发现每个单词的首字母都变为大写字母

date

可以用来显示日期和时间

复制代码
<%- date() %>

要传入的第一个事是想要分开i的日期

frontmatter上的日期,比如有一篇博客文章,可以用它来解析博客前面的日期

或者直接输入当前的日期

复制代码
<%- date(Date.now(), 'YYYY/M/D') %>

这样会提供当前日期和时间,然后给出想要打印使用的格式

time
复制代码
<%- time(Date.now(), 'h:mm:ss a') %>

h:mm:ss是时间格式,a来显示是am还是pm

其余的helper可以查看官方的Hexo文档
Helpers | Hexo


data folder

date foler是一个非常特殊的文件夹

基本上可以用作是网站上的迷你数据库,可以去存储外部数据文件的地方,如果想要在网站内部使用这些文件

在Hexo中存储信息的方式之一是在frontmatter中

有a和b两个md文件

可以知道标题日期和作者

如果想要存储与特定博客文章无关的数据

如果想要访问一般数据

可以使用data folder来实现操作

在source文件夹里,创建一个_data文件夹

在这个文件夹里可以创建数据文件

有两种格式

  1. .json
  2. .yml
    这也是frontmatter可以使用的两种格式
    所以访问数据文件夹和数据文件和访问frontmatter相似

创建一个数据文件myData.yml

这里有一些简单的值,都只有字符串

要做的就是在任何一个模板中去使用这个文件里的信息

转到index.ejs文件

输入

复制代码
<%- site.data.myData.var1 %>

其余的也一样

循环访问data文件中的数据

复制代码
<% for(var value in site.data.myData) { %>

<% } %>

会循环遍历数据文件上的所有值

这些值会存储在var value中

比如要打印这些值

复制代码
<% for(var value in site.data.myData) { %>
	<%- value %> <br>
<% } %>

这样可以打印出所有变量的名称,而不是打印出变量的值

复制代码
<% for(var value in site.data.myData) { %>
	<%- site.data.myData[value] %> <br>
<% } %>

这样就访问了data file里的变量

相关推荐
C++ 老炮儿的技术栈6 分钟前
在C++ 程序中调用被 C编译器编译后的函数,为什么要加 extern “C”声明?
c语言·c++·windows·git·vscode·visual studio
GGGG寄了1 小时前
HTML——文本标签
开发语言·前端·html
Robin罗兵3 小时前
git使用教程2
git
RFCEO3 小时前
HTML编程 课程五、:HTML5 新增语义化标签
前端·html·html5·跨平台·语义化标签·可生成安卓/ios·html最新版本
bob_young6 小时前
Git LFS + Gerrit 配置+lfs-test-server(git lfs push总是提示输入https密码解决)
git·lfs
GGGG寄了6 小时前
HTML——表格的基本用法
前端·html
Filotimo_6 小时前
那在HTML中,action是什么
前端·okhttp·html
半夏微凉半夏殇8 小时前
git add . 是否会包含.o、.so、.ko文件?深度解析与避坑指南
git
牟同學9 小时前
Git 实战场景操作大全(可直接落地)
git
不做无法实现的梦~9 小时前
使用ros2跑mid360的fastlio2建图
git·单片机·嵌入式硬件·gitcode