将butterfly主题修改效果
主题配置 修改 Butterfly 的配置文件 _config.butterfly.yml
。 编辑 index_img、index_top_img_height、background、footer_bg、mask.header 选项。 设置网站背景,将主页顶部图和页脚背景改为透明,调整主页顶部图高度,移除顶部图的黑色半透遮罩。background: url(https://example.com/img/background.jpg ) 将其修改为自己的地址
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 index_img: transparent index_top_img_height: 400px background: url(https://example.com/img/background.jpg) footer_bg: transparent mask: header: false
引入相关样式 新建一个文件,位于 source/css/modify.styl,并增加以下内容。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 @import 'nib' #page-header background : transparent !important &.post-bg , &.not-home-page height : 280px !important #post-info bottom : 40px !important text-align : center #page-site-info top : 140px !important @media screen and (max-width : 768px ) &.not-home-page height : 200px !important #post-info bottom: 10px !important #page-site-info top: 100px !important .top-img height : 250px margin: -50px -40px 50px border-top-left-radius: inherit border-top-right-radius: inherit background-position: center center background-size: cover transition: all 0.3s @media screen and (max-width : 768px ) height : 230px margin: -36px -14px 36px [data-theme='dark'] & filter: brightness(0.8 ) // 页脚 #footer:before background-color: alpha(#FFF, .5 ) [data-theme='dark'] & background-color: alpha(#000 , .5 ) #footer-wrap, #footer-wrap a color : #111 transition: unset [data-theme='dark'] & color : var(--light-grey)
修改 Butterfly 的配置文件 _config.butterfly.yml
,在 inject.head 选项引入样式。
1 2 3 4 5 6 7 8 9 inject: head: - <link rel="stylesheet" href="/css/modify.css">
Hexo 会将 Stylus 渲染成 CSS 文件,所以此处应为 modify.css。
安装插件脚本
新建一个文件,位于 scripts/modify.js
,并增加以下内容。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 'use strict' ;const { filter } = hexo.extend ;const cheerio = require ('cheerio' );function insertTopImg ($ ) { const header = $('#page-header' ); if (header.length === 0 ) return ; const background = header.css ('background-image' ); if (!background) return ; $('#post, #page, #archive, #tag, #category' ).prepend (`<div class="top-img" style="background-image: ${background} ;"></div>` ); } filter.register ('after_render:html' , (str, data ) => { const $ = cheerio.load (str, { decodeEntities : false }); insertTopImg ($); return $.html (); });
此处就已经配置好一图流了
配置文章界面的透明度 新建一个文件,位于 source/css/transpancy.css
,并增加以下内容。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 .layout_post >#post { background : rgba (255 ,255 ,255 ,.8 ); } #aside_content .card-widget , #recent-posts >.recent-post-item , .layout_page >div :first-child :not (.recent-posts ), .layout_post >#page , .layout_post >#post , .read-mode .layout_post >#post { background : rgba (255 ,255 ,255 ,.8 ); } :root { --card-bg : rgba (255 , 255 , 255 , .8 ); } #footer { background : rgba (255 ,255 ,255 , .0 ); }
根据需要调整.8来改变透明度 修改 Butterfly 的配置文件 _config.butterfly.yml
,在 inject.head 选项引入样式。
1 2 3 4 5 6 7 8 9 inject: head: - <link rel="stylesheet" href="/css/transpancy.css">
完成部署
使用插件的方式实现,更新主题时,只要结构变化不大,无需任何操作即可继续使用。参考链接 https://www.cnblogs.com/Code-Rain/p/16905895.html