# hexo-theme-matery **Repository Path**: jackloner/hexo-theme-matery ## Basic Information - **Project Name**: hexo-theme-matery - **Description**: A beautiful hexo blog theme with material design and responsive design.一个基于材料设计和响应式设计而成的全面、美观的Hexo主题。 - **Primary Language**: HTML - **License**: Apache-2.0 - **Default Branch**: develop - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2022-02-05 - **Last Updated**: 2022-05-31 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # hexo-theme-matery [![HitCount](http://hits.dwyl.io/blinkfox/hexo-theme-matery.svg)](http://hits.dwyl.io/blinkfox/hexo-theme-matery) [![Gitter](https://img.shields.io/gitter/room/blinkfox/hexo-theme-matery.svg)](https://gitter.im/hexo-theme-matery/Lobby?utm_source=badge) [![GitHub issues](https://img.shields.io/github/issues/blinkfox/hexo-theme-matery.svg)](https://github.com/blinkfox/hexo-theme-matery/issues) [![GitHub license](https://img.shields.io/github/license/blinkfox/hexo-theme-matery.svg)](https://github.com/blinkfox/hexo-theme-matery/blob/master/LICENSE) [![Download](https://img.shields.io/badge/downloads-master-green.svg)](https://codeload.github.com/blinkfox/hexo-theme-matery/zip/master) [![Hexo Version](https://img.shields.io/badge/hexo-%3E%3D%203.0-blue.svg)](http://hexo.io) [![GitHub forks](https://img.shields.io/github/forks/blinkfox/hexo-theme-matery.svg)](https://github.com/blinkfox/hexo-theme-matery/network) [![GitHub stars](https://img.shields.io/github/stars/blinkfox/hexo-theme-matery.svg)](https://github.com/blinkfox/hexo-theme-matery/stargazers) [English Document](README.md) | [演示示例](https://blinkfox.github.io/) | QQ 交流群: `926552981` > 这是一个采用 `Material Design` 和响应式设计的 Hexo 博客主题。 ## 特性 - 简单漂亮,文章内容美观易读 - [Material Design](https://material.io/) 设计 - 响应式设计,博客在桌面端、平板、手机等设备上均能很好的展现 - 首页轮播文章及每天动态切换 `Banner` 图片 - 瀑布流式的博客文章列表(文章无特色图片时会有 `24` 张漂亮的图片代替) - 时间轴式的归档页 - **词云**的标签页和**雷达图**的分类页 - 丰富的关于我页面(包括关于我、文章统计图、我的项目、我的技能、相册等) - 可自定义的数据的友情链接页面 - 支持文章置顶和文章打赏 - 支持 `MathJax` - `TOC` 目录 - 可设置复制文章内容时追加版权信息 - 可设置阅读文章时做密码验证 - [Gitalk](https://gitalk.github.io/)、[Gitment](https://imsun.github.io/gitment/)、[Valine](https://valine.js.org/) 和 [Disqus](https://disqus.com/) 评论模块(推荐使用 `Gitalk`) - 集成了[不蒜子统计](http://busuanzi.ibruce.info/)、谷歌分析(`Google Analytics`)和文章字数统计等功能 - 支持在首页的音乐播放和视频播放功能 ## 贡献者 感谢下面列出的贡献者,没有他们,hexo-theme-matery 不会这么完美。 - [@HarborZeng](https://github.com/HarborZeng) ## 下载 当你看到这里的时候,应该已经有一个自己的 [Hexo](https://hexo.io/zh-cn/) 博客了。如果还没有的话,不妨使用 Hexo 和 [Markdown](https://www.appinn.com/markdown/) 来写博客和文章。 点击 [这里](https://codeload.github.com/blinkfox/hexo-theme-matery/zip/master) 下载 `master` 分支的最新稳定版的代码,解压缩后,将 `hexo-theme-matery` 的文件夹复制到你 Hexo 的 `themes` 文件夹中即可。 当然你也可以在你的 `themes` 文件夹下使用 `Git clone` 命令来下载: ```bash git clone https://github.com/blinkfox/hexo-theme-matery.git ``` ## 配置 ### 切换主题 修改 Hexo 根目录下的 `_config.yml` 的 `theme` 的值:`theme: hexo-theme-matery` #### `_config.yml` 文件的其它修改建议: - 请修改 `_config.yml` 的 `url` 的值为你的网站主 `URL`(如:`http://xxx.github.io`)。 - 建议修改两个 `per_page` 的分页条数值为 `6` 的倍数,如:`12`、`18` 等,这样文章列表在各个屏幕下都能较好的显示。 - 如果你是中文用户,则建议修改 `language` 的值为 `zh-CN`。 ### 新建分类 categories 页 `categories` 页是用来展示所有分类的页面,如果在你的博客 `source` 目录下还没有 `categories/index.md` 文件,那么你就需要新建一个,命令如下: ```bash hexo new page "categories" ``` 编辑你刚刚新建的页面文件 `/source/categories/index.md`,至少需要以下内容: ```yaml --- title: categories date: 2018-09-30 17:25:30 type: "categories" layout: "categories" --- ``` ### 新建标签 tags 页 `tags` 页是用来展示所有标签的页面,如果在你的博客 `source` 目录下还没有 `tags/index.md` 文件,那么你就需要新建一个,命令如下: ```bash hexo new page "tags" ``` 编辑你刚刚新建的页面文件 `/source/tags/index.md`,至少需要以下内容: ```yaml --- title: tags date: 2018-09-30 18:23:38 type: "tags" layout: "tags" --- ``` ### 新建关于我 about 页 `about` 页是用来展示**关于我和我的博客**信息的页面,如果在你的博客 `source` 目录下还没有 `about/index.md` 文件,那么你就需要新建一个,命令如下: ```bash hexo new page "about" ``` 编辑你刚刚新建的页面文件 `/source/about/index.md`,至少需要以下内容: ```yaml --- title: about date: 2018-09-30 17:25:30 type: "about" layout: "about" --- ``` ### 新建友情连接 friends 页(可选的) `friends` 页是用来展示**友情连接**信息的页面,如果在你的博客 `source` 目录下还没有 `friends/index.md` 文件,那么你就需要新建一个,命令如下: ```bash hexo new page "friends" ``` 编辑你刚刚新建的页面文件 `/source/friends/index.md`,至少需要以下内容: ```yaml --- title: friends date: 2018-12-12 21:25:30 type: "friends" layout: "friends" --- ``` 同时,在你的博客 `source` 目录下新建 `_data` 目录,在 `_data` 目录中新建 `friends.json` 文件,文件内容如下所示: ```json [{ "avatar": "http://image.luokangyuan.com/1_qq_27922023.jpg", "name": "码酱", "introduction": "我不是大佬,只是在追寻大佬的脚步", "url": "http://luokangyuan.com/", "title": "前去学习" }, { "avatar": "http://image.luokangyuan.com/4027734.jpeg", "name": "闪烁之狐", "introduction": "编程界大佬,技术牛,人还特别好,不懂的都可以请教大佬", "url": "https://blinkfox.github.io/", "title": "前去学习" }, { "avatar": "http://image.luokangyuan.com/avatar.jpg", "name": "ja_rome", "introduction": "平凡的脚步也可以走出伟大的行程", "url": "ttps://me.csdn.net/jlh912008548", "title": "前去学习" }] ``` ### 代码高亮 由于 Hexo 自带的代码高亮主题显示不好看,所以主题中使用到了 [hexo-prism-plugin](https://github.com/ele828/hexo-prism-plugin) 的 Hexo 插件来做代码高亮,安装命令如下: ```bash npm i -S hexo-prism-plugin ``` 然后,修改 Hexo 根目录下 `_config.yml` 文件中 `highlight.enable` 的值为 `false`,并新增 `prism` 插件相关的配置,主要配置如下: ```yaml highlight: enable: false prism_plugin: mode: 'preprocess' # realtime/preprocess theme: 'tomorrow' line_number: false # default false custom_css: ``` ### 搜索 本主题中还使用到了 [hexo-generator-search](https://github.com/wzpan/hexo-generator-search) 的 Hexo 插件来做内容搜索,安装命令如下: ```bash npm install hexo-generator-search --save ``` 在 Hexo 根目录下的 `_config.yml` 文件中,新增以下的配置项: ```yaml search: path: search.xml field: post ``` ### 中文链接转拼音(可选的) 如果你的文章名称是中文的,那么 Hexo 默认生成的永久链接也会有中文,这样不利于 `SEO`,且 `gitment` 评论对中文链接也不支持。我们可以用 [hexo-permalink-pinyin](https://github.com/viko16/hexo-permalink-pinyin) Hexo 插件使在生成文章时生成中文拼音的永久链接。 安装命令如下: ```bash npm i hexo-permalink-pinyin --save ``` 在 Hexo 根目录下的 `_config.yml` 文件中,新增以下的配置项: ```yaml permalink_pinyin: enable: true separator: '-' # default: '-' ``` > **注**:除了此插件外,[hexo-abbrlink](https://github.com/rozbo/hexo-abbrlink) 插件也可以生成非中文的链接。 ### 文章字数统计插件(可选的) 如果你想要在文章中显示文章字数、阅读时长信息,可以安装 [hexo-wordcount](https://github.com/willin/hexo-wordcount)插件。 安装命令如下: ```bash npm i --save hexo-wordcount ``` 然后只需在本主题下的 `_config.yml` 文件中,激活以下配置项即可: ```yaml wordCount: enable: false # 将这个值设置为 true 即可. postWordCount: true min2read: true totalCount: true ``` ### 添加 RSS 订阅支持(可选的) 本主题中还使用到了 [hexo-generator-feed](https://github.com/hexojs/hexo-generator-feed) 的 Hexo 插件来做 `RSS`,安装命令如下: ```bash npm install hexo-generator-feed --save ``` 在 Hexo 根目录下的 `_config.yml` 文件中,新增以下的配置项: ```yaml feed: type: atom path: atom.xml limit: 20 hub: content: content_limit: 140 content_limit_delim: ' ' order_by: -date ``` 执行 `hexo clean && hexo g` 重新生成博客文件,然后在 `public` 文件夹中即可看到 `atom.xml` 文件,说明你已经安装成功了。 ### 修改页脚 页脚信息可能需要做定制化修改,而且它不便于做成配置信息,所以可能需要你自己去再修改和加工。修改的地方在主题文件的 `/layout/_partial/footer.ejs` 文件中,包括站点、使用的主题、访问量等。 ### 修改社交链接 在主题的 `_config.yml` 文件中,默认支持 `QQ`、`GitHub` 和邮箱的配置,你可以在主题文件的 `/layout/_partial/social-link.ejs` 文件中,新增、修改你需要的社交链接地址,增加链接可参考如下代码: ```html ``` 其中,社交图标(如:`fa-github`)你可以在 [Font Awesome](https://fontawesome.com/icons) 中搜索找到。以下是常用社交图标的标识,供你参考: - Facebook: `fa-facebook` - Twitter: `fa-twitter` - Google-plus: `fa-google-plus` - Linkedin: `fa-linkedin` - Tumblr: `fa-tumblr` - Medium: `fa-medium` - Slack: `fa-slack` - 新浪微博: `fa-weibo` - 微信: `fa-wechat` - QQ: `fa-qq` > **注意**: 本主题中使用的 `Font Awesome` 版本为 `4.7.0`。 ### 修改打赏的二维码图片 在主题文件的 `source/medias/reward` 文件中,你可以替换成你的的微信和支付宝的打赏二维码图片。 ### 配置音乐播放器(可选的) 要支持音乐播放,就必须开启音乐的播放配置和音乐数据的文件。 首先,在你的博客 `source` 目录下的 `_data` 目录(没有的话就新建一个)中新建 `musics.json` 文件,文件内容如下所示: ```json [{ "name": "五月雨变奏电音", "artist": "AnimeVibe", "url": "http://xxx.com/music1.mp3", "cover": "http://xxx.com/music-cover1.png" }, { "name": "Take me hand", "artist": "DAISHI DANCE,Cecile Corbel", "url": "/medias/music/music2.mp3", "cover": "/medias/music/cover2.png" }, { "name": "Shape of You", "artist": "J.Fla", "url": "http://xxx.com/music3.mp3", "cover": "http://xxx.com/music-cover3.png" }] ``` > **注**:以上 JSON 中的属性:`name`、`artist`、`url`、`cover` 分别表示音乐的名称、作者、音乐文件地址、音乐封面。 然后,在主题的 `_config.yml` 配置文件中激活配置即可: ```yaml # 是否在首页显示音乐. music: enable: true showTitle: false title: 听听音乐 fixed: false # 是否开启吸底模式 autoplay: false # 是否自动播放 theme: '#42b983' loop: 'all' # 音频循环播放, 可选值: 'all', 'one', 'none' order: 'list' # 音频循环顺序, 可选值: 'list', 'random' preload: 'auto' # 预加载,可选值: 'none', 'metadata', 'auto' volume: 0.7 # 默认音量,请注意播放器会记忆用户设置,用户手动设置音量后默认音量即失效 listFolded: false # 列表默认折叠 listMaxHeight: # 列表最大高度 ``` ## 文章 Front-matter 介绍 ### Front-matter 选项详解 `Front-matter` 选项中的所有内容均为**非必填**的。但我仍然建议至少填写 `title` 和 `date` 的值。 | 配置选项 | 默认值 | 描述 | | ---------- | --------------------------- | ------------------------------------------------------------ | | title | `Markdown` 的文件标题 | 文章标题,强烈建议填写此选项 | | date | 文件创建时的日期时间 | 发布时间,强烈建议填写此选项,且最好保证全局唯一 | | author | 根 `_config.yml` 中的 `author` | 文章作者 | | img | `featureImages` 中的某个值 | 文章特征图,推荐使用图床(腾讯云、七牛云、又拍云等)来做图片的路径.如: `http://xxx.com/xxx.jpg` | | top | `true` | 推荐文章(文章是否置顶),如果 `top` 值为 `true`,则会作为首页推荐文章 | | cover | `false` | `v1.0.2`版本新增,表示该文章是否需要加入到首页轮播封面中 | | coverImg | 无 | `v1.0.2`版本新增,表示该文章在首页轮播封面需要显示的图片路径,如果没有,则默认使用文章的特色图片 | | password | 无 | 文章阅读密码,如果要对文章设置阅读验证密码的话,就可以设置 `password` 的值,该值必须是用 `SHA256` 加密后的密码,防止被他人识破。前提是在主题的 `config.yml` 中激活了 `verifyPassword` 选项 | | toc | `true` | 是否开启 TOC,可以针对某篇文章单独关闭 TOC 的功能。前提是在主题的 `config.yml` 中激活了 `toc` 选项 | | mathjax | `false` | 是否开启数学公式支持 ,本文章是否开启 `mathjax`,且需要在主题的 `_config.yml` 文件中也需要开启才行 | | summary | 无 | 文章摘要,自定义的文章摘要内容,如果这个属性有值,文章卡片摘要就显示这段文字,否则程序会自动截取文章的部分内容作为摘要 | | categories | 无 | 文章分类,本主题的分类表示宏观上大的分类,只建议一篇文章一个分类 | | tags | 无 | 文章标签,一篇文章可以多个标签 | | reprintPolicy | cc_by | 文章转载规则, 可以是 cc_by, cc_by_nd, cc_by_sa, cc_by_nc, cc_by_nc_nd, cc_by_nc_sa, cc0, noreprint 或 pay 中的一个 | > **注意**: > 1. 如果 `img` 属性不填写的话,文章特色图会根据文章标题的 `hashcode` 的值取余,然后选取主题中对应的特色图片,从而达到让所有文章都的特色图**各有特色**。 > 2. `date` 的值尽量保证每篇文章是唯一的,因为本主题中 `Gitalk` 和 `Gitment` 识别 `id` 是通过 `date` 的值来作为唯一标识的。 > 3. 如果要对文章设置阅读验证密码的功能,不仅要在 Front-matter 中设置采用了 SHA256 加密的 password 的值,还需要在主题的 `_config.yml` 中激活了配置。有些在线的 SHA256 加密的地址,可供你使用:[开源中国在线工具](http://tool.oschina.net/encrypt?type=2)、[chahuo](http://encode.chahuo.com/)、[站长工具](http://tool.chinaz.com/tools/hash.aspx)。 > 4. 您可以在文章md文件的 front-matter 中指定 reprintPolicy 来给单个文章配置转载规则 以下为文章的 `Front-matter` 示例。 ### 最简示例 ```yaml --- title: typora-vue-theme主题介绍 date: 2018-09-07 09:25:00 --- ``` ### 最全示例 ```yaml --- title: typora-vue-theme主题介绍 date: 2018-09-07 09:25:00 author: 赵奇 img: /source/images/xxx.jpg top: true cover: true coverImg: /images/1.jpg password: 8d969eef6ecad3c29a3a629280e686cf0c3f5d5a86aff3ca12020c923adc6c92 toc: false mathjax: false summary: 这是你自定义的文章摘要内容,如果这个属性有值,文章卡片摘要就显示这段文字,否则程序会自动截取文章的部分内容作为摘要 categories: Markdown tags: - Typora - Markdown --- ``` ## 效果截图 ![首页](http://static.blinkfox.com/matery-20181202-1.png) ![首页推荐文章](http://static.blinkfox.com/matery-20181202-2.png) ![首页文章列表](http://static.blinkfox.com/matery-20181202-3.png) ![首页文章列表](http://static.blinkfox.com/matery-20181202-7.png) ![首页文章列表](http://static.blinkfox.com/matery-20181202-8.png) ## 自定制修改 在本主题的 `_config.yml` 中可以修改部分自定义信息,有以下几个部分: - 菜单 - 我的梦想 - 首页的音乐播放器和视频播放器配置 - 是否显示推荐文章名称和按钮配置 - `favicon` 和 `Logo` - 个人信息 - TOC 目录 - 文章打赏信息 - 复制文章内容时追加版权信息 - MathJax - 文章字数统计、阅读时长 - 点击页面的'爱心'效果 - 我的项目 - 我的技能 - 我的相册 - `Gitalk`、`Gitment`、`Valine` 和 `disqus` 评论配置 - [不蒜子统计](http://busuanzi.ibruce.info/)和谷歌分析(`Google Analytics`) - 默认特色图的集合。当文章没有设置特色图时,本主题会根据文章标题的 `hashcode` 值取余,来选择展示对应的特色图 **我认为个人博客应该都有自己的风格和特色**。如果本主题中的诸多功能和主题色彩你不满意,可以在主题中自定义修改,很多更自由的功能和细节点的修改难以在主题的 `_config.yml` 中完成,需要修改源代码才来完成。以下列出了可能对你有用的地方: ### 修改主题颜色 在主题文件的 `/source/css/matery.css` 文件中,搜索 `.bg-color` 来修改背景颜色: ```css /* 整体背景颜色,包括导航、移动端的导航、页尾、标签页等的背景颜色. */ .bg-color { background-image: linear-gradient(to right, #4cbf30 0%, #0f9d58 100%); } @-webkit-keyframes rainbow { /* 动态切换背景颜色. */ } @keyframes rainbow { /* 动态切换背景颜色. */ } ``` ### 修改 banner 图和文章特色图 你可以直接在 `/source/medias/banner` 文件夹中更换你喜欢的 `banner` 图片,主题代码中是每天动态切换一张,只需 `7` 张即可。如果你会 `JavaScript` 代码,可以修改成你自己喜欢切换逻辑,如:随机切换等,`banner` 切换的代码位置在 `/layout/_partial/bg-cover-content.ejs` 文件的 `` 代码中: ```javascript $('.bg-cover').css('background-image', 'url(/medias/banner/' + new Date().getDay() + '.jpg)'); ``` 在 `/source/medias/featureimages` 文件夹中默认有 24 张特色图片,你可以再增加或者减少,并需要在 `_config.yml` 做同步修改。 ## 版本记录 - v1.0.4 - 新增了能为每篇文章都自定义转载规则的功能; - 修复上一页、下一页的自定义 `summary` 不显示的问题; - 修复了友情链接显示错位的问题,改为了瀑布流的布局方式; - 其他小细节 bug 的修改; - v1.0.3 - 新增了`TOC`展开、收缩的按钮和相关配置,默认显示此按钮; - v1.0.2 - 升级了 [Materialize](https://materializecss.com/) 框架版本为`1.0.0`,重构和修改了升级过程中的部分文件或问题; - 新增了首页封面的全屏轮播特效,可以将更重要的文章设置到首页轮播中; - 修复首页第一个按钮是中文的问题 - 修复了 iPhone 上点击搜索输入获取焦点的问题; - 修复了 iPhone 上输入框获取焦点后页面放大的问题; - 修复一些文章或 UI 显示问题; - v1.0.1 - 调整 `css`、`js` 的文件请求路径在主题的`_config.yml`中配置,便于你更快捷的配置自己的 CDN; - 新增代码是否折行为可配置,默认为折行; - 默认激活 `TOC` 功能,并新增为某篇文章关闭 `TOC` 的 `Front-matter` 配置选项; - 修复文章滚动时,高亮的目录选项不准确的问题; - `IOS`下移除搜索框自动获得焦点属性,防止自动获得焦点后导致视图上移; - v1.0.0 - 新增了所有基础功能;