# 主题安装
Hexo 5.0.0 以上版本支持通过 npm 安装 butterfly 主题
通过 npm 安装会在 node_modules 中生成主题文件夹
node_modules\hexo-theme-butterfly\
在 Hexo 根目录执行
npm i hexo-theme-butterfly
升级方法,执行
npm update hexo-theme-butterfly
修改根目录下的_config.yml
# 大神魔改看板娘(会说话,能换装)
在 node_modules\hexo-theme-butterfly\source\
目录,执行
git clone https://github.com/stevenjoezhang/live2d-widget.git live2d-widget
在 node_modules\hexo-theme-butterfly\source\live2d-widget\autoload.js
,打开 autoload.js
,修改
- const live2d_path = "https://cdn.jsdelivr.net/gh/stevenjoezhang/live2d-widget/"; + const live2d_path = "/live2d-widget/";
在 _config.butterfly.yml
中,添加
# Inject # Insert the code to head (before '</head>' tag) and the bottom (before '</body>' tag) # 插入代码到头部 </head> 之前 和 底部 </body> 之前 inject: head: # - <link rel="stylesheet" href="/xxx.css"> bottom: # - <script src="xxxx"></script> + - <script defer src="/live2d-widget/autoload.js"></script>
为防止主题更新需要重新配置等麻烦,在 hexo根目录\source
新建 js
css
文件夹,之后新加的 js/css 文件一律放在该位置。上述操作需做以下调整:
+ const live2d_path = "/js/live2d-widget/"; + - <script defer src="/js/live2d-widget/autoload.js"></script>
# 页脚计时器
在 Hexo 根目录执行
npm install hexo-butterfly-footer-beautify --save
在 _config.butterfly.yml
中添加
footer_beautify: enable: timer: true bdage: true priority: 5 enable_page: all exclude: layout: type: id name: footer-wrap index: 0 runtime_js: https://npm.elemecdn.com/hexo-butterfly-footer-beautify@1.0.0/lib/runtime.js runtime_css: https://npm.elemecdn.com/hexo-butterfly-footer-beautify@1.0.0/lib/runtime.css swiperpara: 3 bdageitem: - link: https://hexo.io/ shields: https://img.shields.io/badge/Frame-Hexo-blue?style=flat&logo=hexo message: 博客框架为Hexo_v5.4.0 - link: https://butterfly.js.org/ shields: https://img.shields.io/badge/Theme-Butterfly-6513df?style=flat&logo=bitdefender message: 主题版本Butterfly_v3.8.2 - link: https://www.jsdelivr.com/ shields: https://img.shields.io/badge/CDN-jsDelivr-orange?style=flat&logo=jsDelivr message: 本站使用JsDelivr为静态资源提供CDN加速 - link: https://vercel.com/ shields: https://img.shields.io/badge/Hosted-Vercel-brightgreen?style=flat&logo=Vercel message: 本站采用双线部署,默认线路托管于Vercel - link: https://vercel.com/ shields: https://img.shields.io/badge/Hosted-Coding-0cedbe?style=flat&logo=Codio message: 本站采用双线部署,联通线路托管于Coding - link: https://github.com/ shields: https://img.shields.io/badge/Source-Github-d021d6?style=flat&logo=GitHub message: 本站项目由Github托管 - link: http://creativecommons.org/licenses/by-nc-sa/4.0/ shields: https://img.shields.io/badge/Copyright-BY--NC--SA%204.0-d42328?style=flat&logo=Claris message: 本站采用知识共享署名-非商业性使用-相同方式共享4.0国际许可协议进行许可 swiper_css: https://npm.elemecdn.com/hexo-butterfly-swiper/lib/swiper.min.css swiper_js: https://npm.elemecdn.com/hexo-butterfly-swiper/lib/swiper.min.js swiperbdage_init_js: https://npm.elemecdn.com/hexo-butterfly-footer-beautify/lib/swiperbdage_init.min.js
访问 https://npm.elemecdn.com/hexo-butterfly-footer-beautify@1.0.0/lib/runtime.js
,下载并在 node_modules\hexo-theme-butterfly\source\js
新建 runtime.js
,修改其中的时间,并修改 _config.butterfly.yml
- runtime_js: https://npm.elemecdn.com/hexo-butterfly-footer-beautify@1.0.0/lib/runtime.js + runtime_js: /js/runtime.js
# 博客标签魔改
打开 node_modules\hexo-theme-butterfly\scripts\helpers\page.js
文件
在第 52 行 ${tag.name}
后增加 (${tag.length})
即可
result += `<a href="${env.url_for(tag.path)} " style="${style} ">${tag.name} (${tag.length} )</a>`
标签排序
hexo.extend .helper .register ('cloudTags' , function (options = {} ) { const env = this let source = options.source const limit = options.limit source = source.sort ('length' ).reverse () let result = '' if (limit > 0 ) source = source.limit (limit) source.forEach (tag => { const color = 'rgb(' + Math .floor (Math .random () * 201 ) + ', ' + Math .floor (Math .random () * 201 ) + ', ' + Math .floor (Math .random () * 201 ) + ')' result += `<a href="${env.url_for(tag.path)} " style="color: ${color} ">${tag.name} (${tag.length} )</a>` }) return result })
修改样式
#aside-content .card-tag-cloud a { border : 1px solid; line-height : 1.5 ; border-radius : 6px ; margin : 3px ; padding : 0 5px ; } .tag-cloud-list a { border : 1px solid; line-height : 1.5 ; border-radius : 6px ; padding : 5px 15px ; font-size : 1.2rem ; margin : 5px ; }
# 最新文章标签
有不明 bug,暂时不用
打开 node_modules\hexo-theme-butterfly\scripts\helpers\page.js
文件,加入
hexo.extend .helper .register ('newPost' , function ( ) { let name, time; hexo.locals .get ('posts' ).map ((item, index ) => { if (index == 0 ) name = item.title , time = item.date else if (item.date > time) { name = item.title , time = item.date } }); return name })
打开 node_modules\hexo-theme-butterfly\layout\includes\mixins\post-ui.pug
文件,修改
mixin postUI(posts) + - let newTitle= newPost() each article , index in page.posts.data .recent-post-item - let link = article.link || article.path let title = article.title || _p('no_title') const position = theme.cover.position let leftOrRight = position === 'both' ? index%2 == 0 ? 'left' : 'right' : position === 'left' ? 'left' : 'right' let post_cover = article.cover let no_cover = article.cover === false || !theme.cover.index_enable ? 'no-cover' : '' - if post_cover && theme.cover.index_enable .post_cover(class=leftOrRight) a(href=url_for(link) title=title) img.post_bg(src=url_for(post_cover) onerror=`this.onerror=null;this.src='`+ url_for(theme.error_img.post_page) + `'` alt=title) .recent-post-info(class=no_cover) + if newTitle == title + span(class=`newPost-${leftOrRight=='left'?'right':'left'}`) 最新
添加 CSS
#recent-posts >.recent-post-item { position : relative; } .newPost-left ,.newPost-right { position : absolute; top : 0 ; color : white; padding : 0 15px ; background-color : #49b1f5 ; border-radius : 0 0 10px 10px ; } .newPost-left { left : 15px ; } .newPost-right { right : 15px ; }
# 鼠标移动特效
(function fairyDustCursor ( ) { var possibleColors = ["#D61C59" , "#E7D84B" , "#1B8798" ] var width = window .innerWidth ; var height = window .innerHeight ; var cursor = {x : width/2 , y : width/2 }; var particles = []; function init ( ) { bindEvents (); loop (); } function bindEvents ( ) { document .addEventListener ('mousemove' , onMouseMove); document .addEventListener ('touchmove' , onTouchMove); document .addEventListener ('touchstart' , onTouchMove); window .addEventListener ('resize' , onWindowResize); } function onWindowResize (e ) { width = window .innerWidth ; height = window .innerHeight ; } function onTouchMove (e ) { if ( e.touches .length > 0 ) { for ( var i = 0 ; i < e.touches .length ; i++ ) { addParticle ( e.touches [i].clientX , e.touches [i].clientY , possibleColors[Math .floor (Math .random ()*possibleColors.length )]); } } } function onMouseMove (e ) { cursor.x = e.clientX ; cursor.y = e.clientY ; addParticle ( cursor.x , cursor.y , possibleColors[Math .floor (Math .random ()*possibleColors.length )]); } function addParticle (x, y, color ) { var particle = new Particle (); particle.init (x, y, color); particles.push (particle); } function updateParticles ( ) { for ( var i = 0 ; i < particles.length ; i++ ) { particles[i].update (); } for ( var i = particles.length -1 ; i >= 0 ; i-- ) { if ( particles[i].lifeSpan < 0 ) { particles[i].die (); particles.splice (i, 1 ); } } } function loop ( ) { requestAnimationFrame (loop); updateParticles (); } function Particle ( ) { this .character = "*" ; this .lifeSpan = 120 ; this .initialStyles ={ "position" : "fixed" , "top" : "0" , "display" : "block" , "pointerEvents" : "none" , "z-index" : "10000000" , "fontSize" : "20px" , "will-change" : "transform" }; this .init = function (x, y, color ) { this .velocity = { x : (Math .random () < 0.5 ? -1 : 1 ) * (Math .random () / 2 ), y : 1 }; this .position = {x : x - 10 , y : y - 20 }; this .initialStyles .color = color; console .log (color); this .element = document .createElement ('span' ); this .element .innerHTML = this .character ; applyProperties (this .element , this .initialStyles ); this .update (); document .body .appendChild (this .element ); }; this .update = function ( ) { this .position .x += this .velocity .x ; this .position .y += this .velocity .y ; this .lifeSpan --; this .element .style .transform = "translate3d(" + this .position .x + "px," + this .position .y + "px,0) scale(" + (this .lifeSpan / 120 ) + ")" ; } this .die = function ( ) { this .element .parentNode .removeChild (this .element ); } } function applyProperties ( target, properties ) { for ( var key in properties ) { target.style [ key ] = properties[ key ]; } } init (); })();
注意配置文件时填写的属性不要有应该填但没有填的,这种类型问题不会引起错误,但目前发现该问题能对右下角菜单,代码框,搜索栏等产生消失等不可预期影响
白天夜晚切换动画
butterfly 主题实现白天夜晚切换动画
个性名片
个性名片
投币魔改等
投币等魔改
关于js文件报错
hexo会编译source目录下文件,js文件可能会因此异常,找到hexo的`_config.yml`,在`skip_render'处
右下角分享
右下角分享
githubcalendar
emmm,关于这个插件,根据 Akilar 大佬 和小冰大佬 教程自建 api
n 次,但都访问不了,找到了 Zkeq 大佬建好的,可以用,之后会填这个坑的。
[那年今日插件](https://zfe.space/post/hexo-history-calendar.html)
[电子时钟插件](https://akilar.top/posts/4e39cf4a/)
关于Math
本站使用了开发者对于 MathJax 使用的教程
# 归档页面添加文章发布统计图
npm install hexo-charts -S
主题目录/layout/archive.pug
block content include ./includes/mixins/article-sort.pug #archive + #posts-chart
主题目录/layout/page.pug
block content if page.type === 'tags' .tag-cloud + #tags-chart
else if page.type === 'categories' .category-content + #categories-chart
下面是从Akilar大佬处学来的小知识
图标库
详细教学
{% icon [icon-xxxx],[font-size] %}
icon-xxxx:表示图标 font-class, 可以在自己的阿里矢量图标库项目的 font-class 引用方案内查询并复制。
font-size:表示图标大小,直接填写数字即可,单位为 em。图标大小默认值为 1em。
{% icon icon-weixin %} {% icon icon-QQkongjian,2 %} {% icon icon-QQ,1 %} {% icon icon-weixinzhifu,2 %}
行内文本样式
{% u 文本内容 %} {% emp 文本内容 %} {% wavy 文本内容 %} {% del 文本内容 %} {% kbd 文本内容 %} {% psw 文本内容 %}
带 下划线 的文本
带 着重号 的文本
带 波浪线 的文本
带 删除线 的文本
键盘样式的文本 command + D
密码样式的文本:这里没有验证码
1. 带 {% u 下划线 %} 的文本2. 带 {% emp 着重号 %} 的文本3. 带 {% wavy 波浪线 %} 的文本4. 带 {% del 删除线 %} 的文本5. 键盘样式的文本 {% kbd command %} + {% kbd D %}6. 密码样式的文本:{% psw 这里没有验证码 %}
行内文本span
{% span 样式参数(参数以空格划分), 文本内容 %}
字体: logo, code
颜色: red,yellow,green,cyan,blue,gray
大小: small, h4, h3, h2, h1, large, huge, ultra
对齐方向: left, center, right
彩色文字
在一段话中方便插入各种颜色的标签,包括:红色 、黄色 、绿色 、青色 、蓝色 、灰色 。
超大号文字
文档「开始」页面中的标题部分就是超大号文字。
Volantis
A Wonderful Theme for Hexo
- 彩色文字在一段话中方便插入各种颜色的标签,包括:{% span red, 红色 %}、{% span yellow, 黄色 %}、{% span green, 绿色 %}、{% span cyan, 青色 %}、{% span blue, 蓝色 %}、{% span gray, 灰色 %}。 - 超大号文字文档「开始」页面中的标题部分就是超大号文字。 {% span center logo large, Volantis %} {% span center small, A Wonderful Theme for Hexo %}
段落文本p
{% p 样式参数(参数以空格划分), 文本内容 %}
字体: logo, code
颜色: red,yellow,green,cyan,blue,gray
大小: small, h4, h3, h2, h1, large, huge, ultra
对齐方向: left, center, right
彩色文字
在一段话中方便插入各种颜色的标签,包括:红色
、黄色
、绿色
、青色
、蓝色
、灰色
。
超大号文字
文档「开始」页面中的标题部分就是超大号文字。
Volantis
A Wonderful Theme for Hexo
- 彩色文字在一段话中方便插入各种颜色的标签,包括:{% p red, 红色 %}、{% p yellow, 黄色 %}、{% p green, 绿色 %}、{% p cyan, 青色 %}、{% p blue, 蓝色 %}、{% p gray, 灰色 %}。 - 超大号文字文档「开始」页面中的标题部分就是超大号文字。 {% p center logo large, Volantis %} {% p center small, A Wonderful Theme for Hexo %}
引用note
修改主题配置文件
note: style: simple icons: false border_radius: 3 light_bg_offset: 0
方法一
{% note [class] [no-icon] [style] %} Any content (support inline tags too.io). {% endnote %}
方法二
{% note [color] [icon] [style] %} Any content (support inline tags too.io). {% endnote %}
方法一
参数 用法 class 【可选】标识,不同的标识有不同的配色( default /primary/success /info/warning /danger ) no-icon 【可选】不显示 icon style 【可选】可以覆盖配置中的 style(simple/modern/flat/disabled)
方法二
参数 用法 class 【可选】标识,不同的标识有不同的配色( default /blue/pink /red/purple /orange/green ) no-icon 【可选】可配置自定义 icon (只支持 fontawesome 图标,也可以配置 no-icon) style 【可选】可以覆盖配置中的 style(simple/modern/flat/disabled)
方法一
simple 样式 2. modern样式
3. flat样式
4. disabled样式
5. no-icon样式
方法二
simple 样式 2. modern样式
3. flat样式
4. disabled样式
5. no-icon样式
方法一
simple 样式 {% note simple %}默认 提示块标签{% endnote %} {% note default simple %}default 提示块标签{% endnote %} {% note primary simple %}primary 提示块标签{% endnote %} {% note success simple %}success 提示块标签{% endnote %} {% note info simple %}info 提示块标签{% endnote %} {% note warning simple %}warning 提示块标签{% endnote %} {% note danger simple %}danger 提示块标签{% endnote %}{% note simple %}默认 提示块标签{% endnote %} {% note default simple %}default 提示块标签{% endnote %} {% note primary simple %}primary 提示块标签{% endnote %} {% note success simple %}success 提示块标签{% endnote %} {% note info simple %}info 提示块标签{% endnote %} {% note warning simple %}warning 提示块标签{% endnote %} {% note danger simple %}danger 提示块标签{% endnote %}
modern 样式 {% note modern %}默认 提示块标签{% endnote %} {% note default modern %}default 提示块标签{% endnote %} {% note primary modern %}primary 提示块标签{% endnote %} {% note success modern %}success 提示块标签{% endnote %} {% note info modern %}info 提示块标签{% endnote %} {% note warning modern %}warning 提示块标签{% endnote %} {% note danger modern %}danger 提示块标签{% endnote %}
flat 样式 {% note flat %}默认 提示块标签{% endnote %} {% note default flat %}default 提示块标签{% endnote %} {% note primary flat %}primary 提示块标签{% endnote %} {% note success flat %}success 提示块标签{% endnote %} {% note info flat %}info 提示块标签{% endnote %} {% note warning flat %}warning 提示块标签{% endnote %} {% note danger flat %}danger 提示块标签{% endnote %}
disabled 样式 {% note disabled %}默认 提示块标签{% endnote %} {% note default disabled %}default 提示块标签{% endnote %} {% note primary disabled %}primary 提示块标签{% endnote %} {% note success disabled %}success 提示块标签{% endnote %} {% note info disabled %}info 提示块标签{% endnote %} {% note warning disabled %}warning 提示块标签{% endnote %} {% note danger disabled %}danger 提示块标签{% endnote %}
no-icon 样式 {% note no-icon %}默认 提示块标签{% endnote %} {% note default no-icon %}default 提示块标签{% endnote %} {% note primary no-icon %}primary 提示块标签{% endnote %} {% note success no-icon %}success 提示块标签{% endnote %} {% note info no-icon %}info 提示块标签{% endnote %} {% note warning no-icon %}warning 提示块标签{% endnote %} {% note danger no-icon %}danger 提示块标签{% endnote %}
方法二
simple 样式 {% note 'fab fa-cc-visa' simple %}你是刷 Visa 还是 UnionPay{% endnote %} {% note blue 'fas fa-bullhorn' simple %}2021年快到了....{% endnote %} {% note pink 'fas fa-car-crash' simple %}小心开车 安全至上{% endnote %} {% note red 'fas fa-fan' simple%}这是三片呢?还是四片?{% endnote %} {% note orange 'fas fa-battery-half' simple %}你是刷 Visa 还是 UnionPay{% endnote %} {% note purple 'far fa-hand-scissors' simple %}剪刀石头布{% endnote %} {% note green 'fab fa-internet-explorer' simple %}前端最讨厌的浏览器{% endnote %}
modern 样式 {% note 'fab fa-cc-visa' modern %}你是刷 Visa 还是 UnionPay{% endnote %} {% note blue 'fas fa-bullhorn' modern %}2021年快到了....{% endnote %} {% note pink 'fas fa-car-crash' modern %}小心开车 安全至上{% endnote %} {% note red 'fas fa-fan' modern%}这是三片呢?还是四片?{% endnote %} {% note orange 'fas fa-battery-half' modern %}你是刷 Visa 还是 UnionPay{% endnote %} {% note purple 'far fa-hand-scissors' modern %}剪刀石头布{% endnote %} {% note green 'fab fa-internet-explorer' modern %}前端最讨厌的浏览器{% endnote %}
flat 样式 {% note 'fab fa-cc-visa' flat %}你是刷 Visa 还是 UnionPay{% endnote %} {% note blue 'fas fa-bullhorn' flat %}2021年快到了....{% endnote %} {% note pink 'fas fa-car-crash' flat %}小心开车 安全至上{% endnote %} {% note red 'fas fa-fan' flat%}这是三片呢?还是四片?{% endnote %} {% note orange 'fas fa-battery-half' flat %}你是刷 Visa 还是 UnionPay{% endnote %} {% note purple 'far fa-hand-scissors' flat %}剪刀石头布{% endnote %} {% note green 'fab fa-internet-explorer' flat %}前端最讨厌的浏览器{% endnote %}
disabled 样式 {% note 'fab fa-cc-visa' disabled %}你是刷 Visa 还是 UnionPay{% endnote %} {% note blue 'fas fa-bullhorn' disabled %}2021年快到了....{% endnote %} {% note pink 'fas fa-car-crash' disabled %}小心开车 安全至上{% endnote %} {% note red 'fas fa-fan' disabled %}这是三片呢?还是四片?{% endnote %} {% note orange 'fas fa-battery-half' disabled %}你是刷 Visa 还是 UnionPay{% endnote %} {% note purple 'far fa-hand-scissors' disabled %}剪刀石头布{% endnote %} {% note green 'fab fa-internet-explorer' disabled %}前端最讨厌的浏览器{% endnote %}
no-icon 样式 {% note no-icon %}你是刷 Visa 还是 UnionPay{% endnote %} {% note blue no-icon %}2021年快到了....{% endnote %} {% note pink no-icon %}小心开车 安全至上{% endnote %} {% note red no-icon %}这是三片呢?还是四片?{% endnote %} {% note orange no-icon %}你是刷 Visa 还是 UnionPay{% endnote %} {% note purple no-icon %}剪刀石头布{% endnote %} {% note green no-icon %}前端最讨厌的浏览器{% endnote %}
上标标签tip
{% tip [参数,可选] %}文本内容{% endtip %}
样式: success,error,warning,bolt,ban,home,sync,cogs,key,bell
自定义图标:支持 fontawesome。
{% tip %}default{% endtip %} {% tip info %}info{% endtip %} {% tip success %}success{% endtip %} {% tip error %}error{% endtip %} {% tip warning %}warning{% endtip %} {% tip bolt %}bolt{% endtip %} {% tip ban %}ban{% endtip %} {% tip home %}home{% endtip %} {% tip sync %}sync{% endtip %} {% tip cogs %}cogs{% endtip %} {% tip key %}key{% endtip %} {% tip bell %}bell{% endtip %} {% tip fa-atom %}自定义font awesome图标{% endtip %}
动态标签anima
{% tip [参数,可选] %}文本内容{% endtip %}
更多详情请参看 font-awesome-animation 文档
将所需的 CSS 类添加到图标(或 DOM 中的任何元素)。
对于父级悬停样式,需要给目标元素添加指定 CSS 类,同时还要给目标元素的父级元素添加 CSS 类 faa-parent animated-hover。(详情见示例及示例源码)
You can regulate the speed of the animation by adding the CSS class or . faa-fastfaa-slow
可以通过给目标元素添加 CSS 类faa-fast 或faa-slow 来控制动画快慢。
On DOM load 当页面加载时 显示动画
On hover 当鼠标悬停时 显示动画
On parent hover 当鼠标悬停 在父级元素时 显示动画
faa-wrench animated
faa-wrench animated-hover
faa-wrench
faa-ring animated
faa-ring animated-hover
faa-ring
faa-horizontal animated
faa-horizontal animated-hover
faa-horizontal
faa-vertical animated
faa-vertical animated-hover
faa-vertical
faa-flash animated
faa-flash animated-hover
faa-flash
faa-bounce animated
faa-bounce animated-hover
faa-bounce
faa-spin animated
faa-spin animated-hover
faa-spin
faa-tada animated
faa-tada animated-hover
faa-tada
faa-pulse animated
faa-pulse animated-hover
faa-pulse
faa-shake animated
faa-shake animated-hover
faa-shake
faa-tada animated
faa-tada animated-hover
faa-tada
faa-passing animated
faa-passing animated-hover
faa-passing
faa-passing-reverse animated
faa-passing-reverse animated-hover
faa-passing-reverse
faa-burst animated
faa-burst animated-hover
faa-burst
faa-falling animated
faa-falling animated-hover
faa-falling
faa-rising animated
faa-rising animated-hover
faa-rising
On DOM load(当页面加载时显示动画)
2. 调整动画速度
3. On hover(当鼠标悬停时显示动画)
4. On parent hover(当鼠标悬停在父级元素时显示动画)
On DOM load(当页面加载时显示动画)
{% tip warning faa-horizontal animated %}warning{% endtip %} {% tip ban faa-flash animated %}ban{% endtip %}
调整动画速度
{% tip warning faa-horizontal animated faa-fast %}warning{% endtip %} {% tip ban faa-flash animated faa-slow %}ban{% endtip %}
On hover(当鼠标悬停时显示动画)
{% tip warning faa-horizontal animated-hover %}warning{% endtip %} {% tip ban faa-flash animated-hover %}ban{% endtip %}
On parent hover(当鼠标悬停在父级元素时显示动画)
{% tip warning faa-parent animated-hover %}<p class ="faa-horizontal" > warning</p > {% endtip %} {% tip ban faa-parent animated-hover %}<p class ="faa-flash" > ban</p > {% endtip %}
复选列表checkbox
{% checkbox 样式参数(可选), 文本(支持简单md) %}
样式: plus, minus, times
颜色: red ,yellow ,green ,cyan ,blue ,gray
选中状态: checked
{% checkbox 纯文本测试 %} {% checkbox checked, 支持简单的 [markdown}(https://guides.github.com/features/mastering-markdown/) 语法 %} {% checkbox red, 支持自定义颜色 %} {% checkbox green checked, 绿色 + 默认选中 %} {% checkbox yellow checked, 黄色 + 默认选中 %} {% checkbox cyan checked, 青色 + 默认选中 %} {% checkbox blue checked, 蓝色 + 默认选中 %} {% checkbox plus green checked, 增加 %} {% checkbox minus yellow checked, 减少 %} {% checkbox times red checked, 叉 %}
单选列表radio
{% radio 样式参数(可选), 文本(支持简单md) %}
颜色: red ,yellow ,green ,cyan ,blue ,gray
选中状态: checked
{% radio 纯文本测试 %} {% radio checked, 支持简单的 [markdown ](https://guides.github.com/features/mastering-markdown/ ) 语法 %} {% radio red, 支持自定义颜色 %} {% radio green, 绿色 %} {% radio yellow, 黄色 %} {% radio cyan, 青色 %} {% radio blue, 蓝色 %}
时间轴timeline
{% timeline 时间线标题(可选)[,color] %} <!-- timeline 时间节点(标题) --> 正文内容 <!-- endtimeline --> <!-- timeline 时间节点(标题) --> 正文内容 <!-- endtimeline --> {% endtimeline %}
参数
解释
title
标题 / 时间线
color
timeline 颜色:default (留空) /blue/pink /red/purple /orange/green
如果有 hexo-lazyload-image
插件,需要删除并重新安装最新版本,设置 lazyload.isSPA: true
。
2.x 版本的 css 和 js 不适用于 3.x 版本,如果使用了 use_cdn: true
则需要删除。
2.x 版本的 fancybox 标签在 3.x 版本中被重命名为 gallery 。
2.x 版本的置顶 top: true
改为了 pin: true
,并且同样适用于 layout: page
的页面。
如果使用了 hexo-offline
插件,建议卸载,3.0 版本默认开启了 pjax 服务。
全局搜索 seotitle
并替换为 seo_title
。
group 组件的索引规则有变,使用 group 组件的文章内, group: group_name
对应的组件名必须是 group_name
。
group 组件的列表名优先显示文章的 short_title
其次是 title
。
{% timeline 时间轴样式,blue %} <!-- timeline 2020-07-24 [2.6.6 -> 3.0 ](https://github.com/volantis-x/hexo-theme-volantis/releases ) --> 1. 如果有 `hexo-lazyload-image` 插件,需要删除并重新安装最新版本,设置 `lazyload.isSPA: true` 。2. 2.x 版本的 css 和 js 不适用于 3.x 版本,如果使用了 `use_cdn: true` 则需要删除。3. 2.x 版本的 fancybox 标签在 3.x 版本中被重命名为 gallery 。4. 2.x 版本的置顶 `top: true` 改为了 `pin: true` ,并且同样适用于 `layout: page` 的页面。5. 如果使用了 `hexo-offline` 插件,建议卸载,3.0 版本默认开启了 pjax 服务。<!-- endtimeline --> <!-- timeline 2020-05-15 [2.6.3 -> 2.6.6 ](https://github.com/volantis-x/hexo-theme-volantis/releases/tag/2.6.6 ) --> 不需要额外处理。 <!-- endtimeline --> <!-- timeline 2020-04-20 [2.6.2 -> 2.6.3 ](https://github.com/volantis-x/hexo-theme-volantis/releases/tag/2.6.3 ) --> 1. 全局搜索 `seotitle` 并替换为 `seo_title` 。2. group 组件的索引规则有变,使用 group 组件的文章内,`group: group_name` 对应的组件名必须是 `group_name` 。2. group 组件的列表名优先显示文章的 `short_title` 其次是 `title` 。<!-- endtimeline --> {% endtimeline %}
链接卡片link
{% link 标题, 链接, 图片链接(可选) %}
{% link 糖果屋教程贴, https://akilar.top/posts/615e2dec/, /img/siteicon/favicon.ico %}
按钮btns
Volantis 的按钮使用的是btn 和btns 标签。btns 和butterfly 的button 不冲突,但是btn 会被强制渲染,导致部分参数失效,而且btn 的效果还是butterfly 的button 更好看些。所以就只适配了btns 。
{% btns 样式参数 %} {% cell 标题, 链接, 图片或者图标 %} {% cell 标题, 链接, 图片或者图标 %} {% endbtns %}
圆角样式:rounded, circle
增加文字样式:可以在容器内增加 标题 和描述文字
布局方式:
默认为自动宽度,适合视野内只有一两个的情况。
参数
含义
wide
宽一点的按钮
fill
填充布局,自动铺满至少一行,多了会换行
center
居中,按钮之间是固定间距
around
居中分散
grid2
等宽最多 2 列,屏幕变窄会适当减少列数
grid3
等宽最多 3 列,屏幕变窄会适当减少列数
grid4
等宽最多 4 列,屏幕变窄会适当减少列数
grid5
等宽最多 5 列,屏幕变窄会适当减少列数
如果需要显示类似「团队成员」之类的一组含有头像的链接:
2. 或者含有图标的按钮:
3. 圆形图标 + 标题 + 描述 + 图片 + 网格5列 + 居中
如果需要显示类似「团队成员」之类的一组含有头像的链接:
{% btns circle grid5 %} {% cell xaoxuu, https://xaoxuu.com, https://cdn.jsdelivr.net/gh/xaoxuu/cdn-assets/avatar/avatar.png %} {% cell xaoxuu, https://xaoxuu.com, https://cdn.jsdelivr.net/gh/xaoxuu/cdn-assets/avatar/avatar.png %} {% cell xaoxuu, https://xaoxuu.com, https://cdn.jsdelivr.net/gh/xaoxuu/cdn-assets/avatar/avatar.png %} {% cell xaoxuu, https://xaoxuu.com, https://cdn.jsdelivr.net/gh/xaoxuu/cdn-assets/avatar/avatar.png %} {% cell xaoxuu, https://xaoxuu.com, https://cdn.jsdelivr.net/gh/xaoxuu/cdn-assets/avatar/avatar.png %} {% endbtns %}
或者含有图标的按钮:
{% btns rounded grid5 %} {% cell 下载源码, /, fas fa-download %} {% cell 查看文档, /, fas fa-book-open %} {% endbtns %}
圆形图标 + 标题 + 描述 + 图片 + 网格 5 列 + 居中
{% btns circle center grid5 %} <a href ='https://apps.apple.com/cn/app/heart-mate-pro-hrm-utility/id1463348922?ls=1' > <i class ='fab fa-apple' > </i > <b > 心率管家</b > {% p red, 专业版 %} <img src ='https://cdn.jsdelivr.net/gh/xaoxuu/cdn-assets/qrcode/heartmate_pro.png' > </a > <a href ='https://apps.apple.com/cn/app/heart-mate-lite-hrm-utility/id1475747930?ls=1' > <i class ='fab fa-apple' > </i > <b > 心率管家</b > {% p green, 免费版 %} <img src ='https://cdn.jsdelivr.net/gh/xaoxuu/cdn-assets/qrcode/heartmate_lite.png' > </a > {% endbtns %}
github卡片ghcard
{% ghcard 用户名, 其它参数(可选) %} {% ghcard 用户名/仓库, 其它参数(可选) %}
使用,分割各个参数。写法为:参数名 = 参数值
以下只写几个常用参数值。
参数名
取值
释义
hide
stars,commits,prs,issues,contribs
隐藏指定统计
count_private
true
将私人项目贡献添加到总提交计数中
show_icons
true
显示图标
theme
请查阅 Available Themes
主题
用户信息卡片
| {% ghcard xaoxuu %} | {% ghcard xaoxuu, theme=vue %} | | -- | -- | | {% ghcard xaoxuu, theme=buefy %} | {% ghcard xaoxuu, theme=solarized-light %} | | {% ghcard xaoxuu, theme=onedark %} | {% ghcard xaoxuu, theme=solarized-dark %} | | {% ghcard xaoxuu, theme=algolia %} | {% ghcard xaoxuu, theme=calm %} |
仓库信息卡片
| {% ghcard volantis-x/hexo-theme-volantis %} | {% ghcard volantis-x/hexo-theme-volantis, theme=vue %} | | -- | -- | | {% ghcard volantis-x/hexo-theme-volantis, theme=buefy %} | {% ghcard volantis-x/hexo-theme-volantis, theme=solarized-light %} | | {% ghcard volantis-x/hexo-theme-volantis, theme=onedark %} | {% ghcard volantis-x/hexo-theme-volantis, theme=solarized-dark %} | | {% ghcard volantis-x/hexo-theme-volantis, theme=algolia %} | {% ghcard volantis-x/hexo-theme-volantis, theme=calm %} |
github徽标ghbdage
{% bdage [right],[left],[logo]||[color],[link],[title]||[option] %}
left :徽标左边的信息,必选参数。
right : 徽标右边的信息,必选参数。
logo :徽标图标,图标名称详见simpleicons ,可选参数。
color :徽标右边的颜色,可选参数。
link :指向的链接,可选参数。
title :徽标的额外信息,可选参数。主要用于优化 SEO,但object 标签不会像a 标签一样在鼠标悬停显示title 信息。
option :自定义参数,支持shields.io 的全部 API 参数支持,具体参数可以参看上文中的拓展写法示例。形式为name1=value2&name2=value2 。
1. 基本参数,定义徽标左右文字和图标
2. 信息参数,定义徽标右侧内容背景色,指向链接
3. 拓展参数,支持shields的API的全部参数内容
1. 基本参数,定义徽标左右文字和图标
{% bdage Theme,Butterfly %} {% bdage Frame,Hexo,hexo %}
2. 信息参数,定义徽标右侧内容背景色,指向链接
{% bdage CDN,JsDelivr,jsDelivr||abcdef,https://metroui.org.ua/index.html,本站使用JsDelivr为静态资源提供CDN加速 %} {% bdage Source,GitHub,GitHub||,https://github.com/ %}
3. 拓展参数,支持shields的API的全部参数内容
{% bdage Hosted,Vercel,Vercel||brightgreen,https://vercel.com/,本站采用双线部署,默认线路托管于Vercel||style=social&logoWidth=20 %} //如果是跨顺序省略可选参数组,仍然需要写双竖线||用作分割 {% bdage Hosted,Vercel,Vercel||||style=social&logoWidth=20&logoColor=violet %}
网站卡片sites
{% sitegroup %} {% site 标题, url=链接, screenshot=截图链接, avatar=头像链接(可选), description=描述(可选) %} {% site 标题, url=链接, screenshot=截图链接, avatar=头像链接(可选), description=描述(可选) %} {% endsitegroup %}
{% sitegroup %} {% site xaoxuu, url=https://xaoxuu.com, screenshot=https://i.loli.net/2020/08/21/VuSwWZ1xAeUHEBC.jpg, avatar=https://cdn.jsdelivr.net/gh/xaoxuu/cdn-assets/avatar/avatar.png, description=简约风格 %} {% site inkss, url=https://inkss.cn, screenshot=https://i.loli.net/2020/08/21/Vzbu3i8fXs6Nh5Y.jpg, avatar=https://cdn.jsdelivr.net/gh/inkss/common@master/static/web/avatar.jpg, description=这是一段关于这个网站的描述文字 %} {% site MHuiG, url=https://blog.mhuig.top, screenshot=https://i.loli.net/2020/08/22/d24zpPlhLYWX6D1.png, avatar=https://cdn.jsdelivr.net/gh/MHuiG/imgbed@master/data/p.png, description=这是一段关于这个网站的描述文字 %} {% site Colsrch, url=https://colsrch.top, screenshot=https://i.loli.net/2020/08/22/dFRWXm52OVu8qfK.png, avatar=https://cdn.jsdelivr.net/gh/Colsrch/images/Colsrch/avatar.jpg, description=这是一段关于这个网站的描述文字 %} {% site Linhk1606, url=https://linhk1606.github.io, screenshot=https://i.loli.net/2020/08/21/3PmGLCKicnfow1x.png, avatar=https://i.loli.net/2020/02/09/PN7I5RJfFtA93r2.png, description=这是一段关于这个网站的描述文字 %} {% endsitegroup %}
行内图片inlineimage
{% inlineimage 图片链接, height=高度(可选) %}
这是 一段话。
这又是 一段话。
这是 {% inlineimage https://cdn.jsdelivr.net/gh/volantis-x/cdn-emoji/aru-l/0000.gif %} 一段话。 这又是 {% inlineimage https://cdn.jsdelivr.net/gh/volantis-x/cdn-emoji/aru-l/5150.gif, height=40px %} 一段话。
单张图片image
{% image 链接, width=宽度(可选), height=高度(可选), alt=描述(可选), bg=占位颜色(可选) %}
图片宽度高度:width=300px, height=32px
图片描述:alt = 图片描述(butterfly 需要在主题配置文件中开启图片描述)
占位背景色:bg=#f2f2f2
添加描述:
2. 指定宽度:
3. 指定宽度并添加描述:
4. 设置占位背景色:
添加描述:
{% image https://cdn.jsdelivr.net/gh/volantis-x/cdn-wallpaper-minimalist/2020/025.jpg, alt=每天下课回宿舍的路,没有什么故事。 %}
指定宽度:
{% image https://cdn.jsdelivr.net/gh/volantis-x/cdn-wallpaper-minimalist/2020/025.jpg, width=400px %}
指定宽度并添加描述:
{% image https://cdn.jsdelivr.net/gh/volantis-x/cdn-wallpaper-minimalist/2020/025.jpg, width=400px, alt=每天下课回宿舍的路,没有什么故事。 %}
设置占位背景色:
{% image https://cdn.jsdelivr.net/gh/volantis-x/cdn-wallpaper-minimalist/2020/025.jpg, width=400px, bg=#1D0C04, alt=优化不同宽度浏览的观感 %}
音频audio
Your browser does not support the audio tag. {% audio https://github.com/volantis-x/volantis-docs/releases/download/assets/Lumia1020.mp3 %}
视频video
对其方向:left, center, right
列数:逗号后面直接写列数,支持 1 ~ 4 列。
100% 宽度
Your browser does not support the video tag.
2. 50%宽度
Your browser does not support the video tag.
Your browser does not support the video tag.
Your browser does not support the video tag.
Your browser does not support the video tag.
3. 25%宽度
Your browser does not support the video tag.
Your browser does not support the video tag.
Your browser does not support the video tag.
Your browser does not support the video tag.
Your browser does not support the video tag.
Your browser does not support the video tag.
Your browser does not support the video tag.
Your browser does not support the video tag.
100% 宽度
{% video https://github.com/volantis-x/volantis-docs/releases/download/assets/IMG_0341.mov %}
50% 宽度
{% videos, 2 %} {% video https://github.com/volantis-x/volantis-docs/releases/download/assets/IMG_0341.mov %} {% video https://github.com/volantis-x/volantis-docs/releases/download/assets/IMG_ 0341.mov %}{% video https://github.com/volantis-x/volantis-docs/releases/download/assets/IMG_0341.mov %} {% video https://github.com/volantis-x/volantis-docs/releases/download/assets/IMG_ 0341.mov %}{% endvideos %}
25% 宽度
{% videos, 4 %} {% video https://github.com/volantis-x/volantis-docs/releases/download/assets/IMG_0341.mov %} {% video https://github.com/volantis-x/volantis-docs/releases/download/assets/IMG_ 0341.mov %}{% video https://github.com/volantis-x/volantis-docs/releases/download/assets/IMG_0341.mov %} {% video https://github.com/volantis-x/volantis-docs/releases/download/assets/IMG_ 0341.mov %}{% video https://github.com/volantis-x/volantis-docs/releases/download/assets/IMG_0341.mov %} {% video https://github.com/volantis-x/volantis-docs/releases/download/assets/IMG_ 0341.mov %}{% video https://github.com/volantis-x/volantis-docs/releases/download/assets/IMG_0341.mov %} {% video https://github.com/volantis-x/volantis-docs/releases/download/assets/IMG_ 0341.mov %}{% endvideos %}
相册gallery
gallerygroup 相册图库
<div class ="gallery-group-main" > {% galleryGroup name description link img-url %} {% galleryGroup name description link img-url %} {% galleryGroup name description link img-url %} </div >
gallery 相册
{% gallery %} markdown 圖片格式 {% endgallery %}
参数名
释义
name
图库名字
description
图库描述
link
链接到对应相册的地址
img-url
图库封面
思维拓展一下,相册图库的实质其实就是个快捷方式,可以自定义添加描述、封面、链接。那么我们未必要把它当做一个相册,完全可以作为一个链接卡片,链接到视频、QQ、友链都是不错的选择。
区别于旧版的 Gallery 相册,新的 Gallery 相册会自动根据图片长度进行排版,书写也更加方便,与 markdown 格式一样。可根据需要插入到相应的 md。无需再自己配置长宽。建议在粘贴时故意使用长短、大小、横竖不一的图片,会有更好的效果。(尺寸完全相同的图片只会平铺输出,效果很糟糕)
gallerygroup 相册图库
MC
在Rikkaの六花服务器里留下的足迹
Gundam
哦咧哇gundam哒!
I-am-Akilar
某种意义上也算自拍吧
2. gallery相册
对于很多同学提问的gallerygroup 和gallery 相册页的链接问题。这里说下我个人的使用习惯。
一般使用相册图库的话,可以在导航栏加一个 gallery 的 page (使用指令hexo new page gallery 添加),里面放相册图库作为封面。然后在[Blogroot]/source/gallery/ 下面建立相应的文件夹,例如若按照这里的示例,若欲使用/gallery/MC/ 路径访问 MC 相册,则需要新建[Blogroot]/source/gallery/MC/index.md ,并在里面填入gallery 相册内容。
1. gallerygroup相册图库
<div class ="gallery-group-main" > {% galleryGroup MC 在Rikkaの六花服务器里留下的足迹 '/gallery/MC/' https://assets.akilar.top/image/1.jpg %} {% galleryGroup Gundam 哦咧哇gundam哒! '/gallery/Gundam/' https://assets.akilar.top/image/20200907110508327.png %} {% galleryGroup I-am-Akilar 某种意义上也算自拍吧 '/gallery/I-am-Akilar/' https://assets.akilar.top/image/20200907113116651.png %} </div >
2. gallery相册
{% gallery %} ![](https://i.loli.net/2019/12/25/Fze9jchtnyJXMHN.jpg ) ![](https://i.loli.net/2019/12/25/ryLVePaqkYm4TEK.jpg ) ![](https://i.loli.net/2019/12/25/gEy5Zc1Ai6VuO4N.jpg ) ![](https://i.loli.net/2019/12/25/d6QHbytlSYO4FBG.jpg ) ![](https://i.loli.net/2019/12/25/6nepIJ1xTgufatZ.jpg ) ![](https://i.loli.net/2019/12/25/E7Jvr4eIPwUNmzq.jpg ) ![](https://i.loli.net/2019/12/25/mh19anwBSWIkGlH.jpg ) ![](https://i.loli.net/2019/12/25/2tu9JC8ewpBFagv.jpg ) {% endgallery %}
折叠框folding
{% folding 参数(可选), 标题 %} ![](https://cdn.jsdelivr.net/gh/volantis-x/cdn-wallpaper/abstract/41F215B9-261F-48B4-80B5-4E86E165259E.jpeg ) {% endfolding %}
颜色:blue, cyan, green, yellow, red
状态:状态填写 open 代表默认打开。
查看图片测试
查看默认打开的折叠框
查看代码测试
查看列表测试
查看嵌套测试
查看嵌套测试2 查看嵌套测试3 hahaha
{% folding 查看图片测试 %} ![](https://cdn.jsdelivr.net/gh/volantis-x/cdn-wallpaper/abstract/41F215B9-261F-48B4-80B5-4E86E165259E.jpeg ) {% endfolding %} {% folding cyan open, 查看默认打开的折叠框 %} 这是一个默认打开的折叠框。 {% endfolding %} {% folding green, 查看代码测试 %} 假装这里有代码块(代码块没法嵌套代码块) {% endfolding %} {% folding yellow, 查看列表测试 %} - haha- hehe{% endfolding %} {% folding red, 查看嵌套测试 %} {% folding blue, 查看嵌套测试2 %} {% folding 查看嵌套测试3 %} hahaha <span > <img src ='https://cdn.jsdelivr.net/gh/volantis-x/cdn-emoji/tieba/%E6%BB%91%E7%A8%BD.png' style ='height:24px' > </span > {% endfolding %} {% endfolding %} {% endfolding %}
分栏tab
{% tabs Unique name, [index] %} <!-- tab [Tab caption] [@icon] --> Any content (support inline tags too). <!-- endtab --> {% endtabs %}
Unique name :
选项卡块标签的唯一名称,不带逗号。
将在 #id 中用作每个标签及其索引号的前缀。
如果名称中包含空格,则对于生成 #id,所有空格将由破折号代替。
仅当前帖子 / 页面的 URL 必须是唯一的!
[index]:
活动选项卡的索引号。
如果未指定,将选择第一个标签(1)。
如果 index 为 - 1,则不会选择任何选项卡。
可选参数。
[Tab caption]:
当前选项卡的标题。
如果未指定标题,则带有制表符索引后缀的唯一名称将用作制表符的标题。
如果未指定标题,但指定了图标,则标题将为空。
可选参数。
[@icon]:
FontAwesome 图标名称(全名,看起来像 “fas fa-font”)
可以指定带空格或不带空格;
例如’Tab caption @icon’ 和 ‘Tab caption@icon’.
可选参数。
Demo 4 - 自定义 Tab 名 + 只有 icon + icon 和 Tab 名
{% tabs test1 %} <!-- tab --> **This is Tab 1.** <!-- endtab --> <!-- tab --> **This is Tab 2.** <!-- endtab --> <!-- tab --> **This is Tab 3.** <!-- endtab --> {% endtabs %}
{% tabs test2, 3 %} <!-- tab --> **This is Tab 1.** <!-- endtab --> <!-- tab --> **This is Tab 2.** <!-- endtab --> <!-- tab --> **This is Tab 3.** <!-- endtab --> {% endtabs %}
{% tabs test3, -1 %} <!-- tab --> **This is Tab 1.** <!-- endtab --> <!-- tab --> **This is Tab 2.** <!-- endtab --> <!-- tab --> **This is Tab 3.** <!-- endtab --> {% endtabs %}
Demo 4 - 自定义 Tab 名 + 只有 icon + icon 和 Tab 名
{% tabs test4 %} <!-- tab 第一个Tab --> **tab名字为第一个Tab** <!-- endtab --> <!-- tab @fab fa-apple-pay --> **只有图标 没有Tab名字** <!-- endtab --> <!-- tab 炸弹@fas fa-bomb --> **名字+icon** <!-- endtab --> {% endtabs %}
数据集合 issues
{% issues type | api=url | group=key:value1,value2(可选) %}
type (类型):
根据需求不同,会将 issues 内容解析成不同的 HTML 标签,目前支持的类型有:
时间轴 timeline: 解析成 timeline 标签,issue 的标题对应 timeline 的时间,issue 的内容对应 timeline 的内容。
网站卡片 sites: 解析成 sites 标签,需要有 JSON 代码块,各参数对应 sites 标签参数:
{ "title" : "" , "screenshot" : "" , "url" : "" , "avatar" : "" , "description" : "" , "「keywords」" : "" }
参数
释义
title
网站名称
screenshot
网站预览图
url
网站链接,需要添加https:// 协议组成完整域名 。 否则可能被识别成站点相对路径。
avatar
站长头像
「keywords」
分组依据, 未必要叫「keywords」, 详见下文 group (分组)
api (接口):
url 为可以调的通的 API,例如:
api=https://gitee.com/api/v5/repos/xaoxuu/friends/issues?sort=updated&state=open&page=1&per_page=100&labels=active api=https://api.github.com/repos/xaoxuu/friends/issues?sort=updated&state=open&page=1&per_page=100&labels=active
参数
释义
https://gitee.com/api/v5/
gitee 仓库的 api
https://api.github.com/
github 仓库的 api
repos/xaoxuu/friends/issues
repos / 用户名 / 仓库名 /issues
sort=updated&state=open
界定哪些类型的 issues 会被读取过来渲染成相应的标签
page=1&per_page=100
读取前 100 条 issues
labels=active
控制默认的 issue 不显示, 只有自己审核通过 添加了 active 标签之后才会显示
group (分组):
sites 类型的 issues 默认不分组,如果需要分组,可指定分组依据「keywords」,和分组白名单「value1」、「value2」等,例如:
这个参数的作用就是,筛选出 JSON 中包含 "version": “v4"或者"version”:“v3"或者"version”: "v2" 的数据,并分组显示。
仓库 ISSUES 模板配置
详细内容见
时间轴标签 timeline 渲染
2. 网站卡片标签sites渲染
- gitee仓库示例
- github仓库示例
3. 网站卡片标签sites分组渲染
这是Volantis主题官网的「示例博客」页面的数据:
时间轴标签 timeline 渲染
{% issues timeline | api=https://gitee.com/api/v5/repos/xaoxuu/timeline/issues?state=open&creator=xaoxuu&sort=created&direction=desc&page=1&per_page=100 %}
网站卡片标签 sites 渲染
{% issues sites | api=https://gitee.com/api/v5/repos/xaoxuu/friends/issues?sort=updated&state=open&page=1&per_page=100&labels=active %}
{% issues sites | api=https://api.github.com/repos/xaoxuu/friends/issues?sort=updated&state=open&page=1&per_page=100&labels=active %}
网站卡片标签 sites 分组渲染
这是 Volantis 主题官网的「示例博客」页面的数据:
{% issues sites | api=https://api.github.com/repos/volantis-x/examples/issues?sort=updated&state=open&page=1&per_page=100 | group=version:版本:^4.0,版本:^3.0,版本:^2.0 %}
诗词标签 poem
{% poem [title],[author] %} 诗词内容 {% endpoem %}
title:诗词标题
author:作者,可以不写
水调歌头
苏轼
丙辰中秋,欢饮达旦,大醉,作此篇,兼怀子由。
明月几时有?把酒问青天。
不知天上宫阙,今夕是何年?
我欲乘风归去,又恐琼楼玉宇,高处不胜寒。
起舞弄清影,何似在人间?
转朱阁,低绮户,照无眠。
不应有恨,何事长向别时圆?
人有悲欢离合,月有阴晴圆缺,此事古难全。
但愿人长久,千里共婵娟。
{% poem 水调歌头,苏轼 %} 丙辰中秋,欢饮达旦,大醉,作此篇,兼怀子由。 明月几时有?把酒问青天。 不知天上宫阙,今夕是何年? 我欲乘风归去,又恐琼楼玉宇,高处不胜寒。 起舞弄清影,何似在人间? 转朱阁,低绮户,照无眠。 不应有恨,何事长向别时圆? 人有悲欢离合,月有阴晴圆缺,此事古难全。 但愿人长久,千里共婵娟。 {% endpoem %}
特效标签wow
{% wow [animete],[duration],[delay],[offset],[iteration] %} 内容 {% endwow %}
animate: 动画样式,效果详见 animate.css 参考文档
duration: 选填项,动画持续时间,单位可以是 ms 也可以是 s。例如 3s,700ms。
delay: 选填项,动画开始的延迟时间,单位可以是 ms 也可以是 s。例如 3s,700ms。
offset: 选填项,开始动画的距离(相对浏览器底部)
iteration: 选填项,动画重复的次数
flip 动画效果.
zoomIn 动画效果,持续 5s,延时 5s,离底部 100 距离时启动,重复 10 次。
zoomIn
动画效果,持续 5s
,延时 5s
,离底部 100
距离时启动,重复 10
次
slideInRight 动画效果,持续 5s,延时 5s。
slideInRight
动画效果,持续 5s
,延时 5s
。
heartBeat 动画效果,延时 5s,重复 10 次。此处注意不用的参数位置要留空,用逗号间隔。
heartBeat
动画效果,延时 5s
,重复 10
次。
flip 动画效果.
{% wow animate__flip %} {% note green 'fas fa-fan' modern%} `flip`动画效果。 {% endnote %} {% endwow %}
zoomIn 动画效果,持续 5s,延时 5s,离底部 100 距离时启动,重复 10 次。
{% wow animate__zoomIn,5s,5s,100,10 %} {% note blue 'fas fa-bullhorn' modern%} `zoomIn`动画效果,持续`5s`,延时`5s`,离底部`100`距离时启动,重复`10`次 {% endnote %} {% endwow %}
slideInRight 动画效果,持续 5s,延时 5s。
{% wow animate__slideInRight,5s,5s %} {% note orange 'fas fa-car' modern%} `slideInRight`动画效果,持续`5s`,延时`5s`。 {% endnote %} {% endwow %}
heartBeat 动画效果,延时 5s,重复 10 次。此处注意不用的参数位置要留空,用逗号间隔。
{% wow animate__heartBeat,,5s,,10 %} {% note red 'fas fa-battery-half' modern%} `heartBeat`动画效果,延时`5s`,重复`10`次。 {% endnote %} {% endwow %}
进度条 progress
{% progress [width] [color] [text] %}
width: 0 到 100 的阿拉伯数字
color: 颜色,取值有 red,yellow,green,cyan,blue,gray
text: 进度条上的文字内容
{% progress 10 red 进度条样式预览 %} {% progress 30 yellow 进度条样式预览 %} {% progress 50 green 进度条样式预览 %} {% progress 70 cyan 进度条样式预览 %} {% progress 90 blue 进度条样式预览 %} {% progress 100 gray 进度条样式预览 %}
注释 notation
{% nota [label] , [text] %}
label: 注释词汇
text: 悬停显示的注解内容
{% nota 把鼠标移动到我上面试试 ,可以看到注解内容出现在顶栏 %}
气泡注释 bubble
{% bubble [content] , [notation] ,[background-color] %}
content: 注释词汇
notation: 悬停显示的注解内容
background-color: 可选,气泡背景色。默认为 “#71a4e3”
最近我学到了不少新玩意儿(虽然对很多大佬来说这些已经是旧技术了),比如 CSS 的兄弟相邻选择器 例如 h1 + p {margin-top:50px;} ,flex 布局 Flex 是 Flexible Box 的缩写,意为弹性布局 ",用来为盒状模型提供最大的灵活性" ,transform 变换 transform 属性向元素应用 2D 或 3D 转换。该属性允许我们对元素进行旋转、缩放、移动或倾斜。 ,animation 的贝塞尔速度曲线 贝塞尔曲线 (Bézier curve),又称贝兹曲线或贝济埃曲线,是应用于二维图形应用程序的数学曲线。一般的矢量图形软件通过它来精确画出曲线,贝兹曲线由线段与节点组成,节点是可拖动的支点,线段像可伸缩的皮筋 写法,还有今天刚看到的clip-path clip-path 属性使用裁剪方式创建元素的可显示区域。区域内的部分显示,区域外的隐藏。 属性。这些对我来说很新颖的概念狠狠的冲击着我以前积累起来的设计思路。
最近我学到了不少新玩意儿(虽然对很多大佬来说这些已经是旧技术了),比如CSS的{% bubble 兄弟相邻选择器,"例如 h1 + p {margin-top:50px;}" %},{% bubble flex布局,"Flex 是 Flexible Box 的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性","#ec5830" %},{% bubble transform变换,"transform 属性向元素应用 2D 或 3D 转换。该属性允许我们对元素进行旋转、缩放、移动或倾斜。","#1db675" %},animation的{% bubble 贝塞尔速度曲线,"贝塞尔曲线(Bézier curve),又称贝兹曲线或贝济埃曲线,是应用于二维图形应用程序的数学曲线。一般的矢量图形软件通过它来精确画出曲线,贝兹曲线由线段与节点组成,节点是可拖动的支点,线段像可伸缩的皮筋","#de4489" %}写法,还有今天刚看到的{% bubble clip-path,"clip-path属性使用裁剪方式创建元素的可显示区域。区域内的部分显示,区域外的隐藏。","#868fd7" %}属性。这些对我来说很新颖的概念狠狠的冲击着我以前积累起来的设计思路。
引用文献 reference
{% referto [id] , [literature] %} {% referfrom [id] , [literature] , [url] %}
考虑到锚点跳转的特性,不建议您将引用出处标签 referfrom 写在常隐外挂标签 (如 folding、tab、hideToggle) 中,这样能有效避免跳转失败。
referto 引用上标
id: 上标序号内容,需与 referfrom 标签的 id 对应才能实现跳转
literature: 引用的参考文献名称
referfrom 引用出处
id: 序号内容,需与 referto 标签的 id 对应才能实现跳转
literature: 引用的参考文献名称
url: 引用的参考文献链接,可省略
Akilar の糖果屋 (akilar.top) 是一个私人性质的博客[1] Akilar の糖果屋群聊简介 参考资料 ,从各类教程至生活点滴,无话不谈。建群的目的是提供一个闲聊的场所。博客采用 Hexo 框架[2] Hexo 中文文档 参考资料 ,Butterfly 主题[3] Butterfly 安装文档 (一) 快速开始 参考资料
本项目参考了 Volantis[4] hexo-theme-volantis 标签插件 参考资料 的标签样式。引入 [tag].js
,并针对 butterfly
主题修改了相应的 [tag].styl
。在此鸣谢 Volantis
主题众开发者。
主要参考内容包括各个 volantis 的内置标签插件文档[5] Volantis 文档:内置标签插件 参考资料
Butterfly 主题的各个衍生魔改[6] Butterfly 安装文档:标签外挂(Tag Plugins 参考资料 [7] 小弋の生活馆全样式预览 参考资料 [8] l-lin-font-awesome-animation 参考资料 [9] 小康的 butterfly 主题使用文档 参考资料
Akilarの糖果屋(akilar.top)是一个私人性质的博客{% referto '[1]','Akilarの糖果屋群聊简介' %},从各类教程至生活点滴,无话不谈。建群的目的是提供一个闲聊的场所。博客采用Hexo框架{% referto '[2]','Hexo中文文档' %},Butterfly主题{% referto '[3]','Butterfly 安装文档(一) 快速开始' %} 本项目参考了Volantis{% referto '[4]','hexo-theme-volantis 标签插件' %}的标签样式。引入`[tag].js` ,并针对`butterfly` 主题修改了相应的`[tag].styl` 。在此鸣谢`Volantis` 主题众开发者。 主要参考内容包括各个volantis的内置标签插件文档{% referto '[5]','Volantis文档:内置标签插件' %} Butterfly主题的各个衍生魔改{% referto '[6]','Butterfly 安装文档:标签外挂(Tag Plugins' %}{% referto '[7]','小弋の生活馆全样式预览' %}{% referto '[8]','l-lin-font-awesome-animation' %}{% referto '[9]','小康的butterfly主题使用文档' %} {% referfrom '[1]','Akilarの糖果屋群聊简介','https://jq.qq.com/?_wv=1027&k=pGLB2C0N' %} {% referfrom '[2]','Hexo中文文档','https://hexo.io/zh-cn/docs/' %} {% referfrom '[3]','Butterfly 安装文档(一) 快速开始','https://butterfly.js.org/posts/21cfbf15/' %} {% referfrom '[4]','hexo-theme-volantis 标签插件','https://volantis.js.org/v5/tag-plugins/' %} {% referfrom '[5]','Volantis文档:内置标签插件','https://volantis.js.org/tag-plugins/' %} {% referfrom '[6]','Butterfly 安装文档:标签外挂(Tag Plugins','https://butterfly.js.org/posts/4aa8abbe/#%E6%A8%99%E7%B1%A4%E5%A4%96%E6%8E%9B%EF%BC%88Tag-Plugins%EF%BC%89' %} {% referfrom '[7]','小弋の生活馆全样式预览','https://lovelijunyi.gitee.io/posts/c898.html' %} {% referfrom '[8]','l-lin-font-awesome-animation','https://github.com/l-lin/font-awesome-animation' %} {% referfrom '[9]','小康的butterfly主题使用文档','https://www.antmoe.com/posts/3b43914f/' %}
旋转相册 carousel
{% carousel [Id] , [name] %} ![](/img/1.jpg ) ![](/img/2.jpg ) ![](/img/3,jpg ) {% endcarousel %}
Id: 相册唯一 ID,用于监测相册鼠标动作。禁止使用中文。同一页内不得出现相同 ID 的 carousel 相册。
name: 相册中间显示的内容,建议用英文单引号包裹。
{% carousel 'SF','strike freedom' %} ![](https://assets.akilar.top/image/20200907110444226.png ) ![](https://assets.akilar.top/image/20200907110508327.png ) ![](https://assets.akilar.top/image/20200907110525753.png ) ![](https://assets.akilar.top/image/20200907110600751.png ) ![](https://assets.akilar.top/image/20200907110621554.png ) ![](https://assets.akilar.top/image/20200907110637459.png ) ![](https://assets.akilar.top/image/20200907110654150.png ) ![](https://assets.akilar.top/image/20200907110707916.png ) ![](https://assets.akilar.top/image/20200907110719787.png ) ![](https://assets.akilar.top/image/20200907110731118.png ) {% endcarousel %}