介绍 之前在「博客迁移至 Hexo,并更名为矩阵。 」提到过一图流背景与顶部图的修改。
本文会详细说明修改过程。
主题配置 修改 Butterfly  的配置文件 _config.butterfly.yml。
编辑 index_img、footer_img、background、index_top_img_height、mask.header 选项。(需要将示例地址替换为自己的图片地址。) 
_config.butterfly.yml 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 index_img:  transparent footer_img:  transparent background:  https://example.com/img/background.jpg index_top_img_height:  400px mask:   header:  false  
引入相关样式 新建一个文件,位于 source/css/modify.styl,并增加以下内容。(此处只是举例,也可以使用已有的样式文件。) 
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   background-size: cover   transition: all .3s    @media screen and  (max-width : 768px )     height : 230px      margin: -36px  -14px  36px    [data-theme='dark'] &     filter: brightness(.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 选项引入样式。
_config.butterfly.yml 1 2 3 4 5 6 7 8 9 inject:   head:      -  <link  rel="stylesheet"  href="/css/modify.css">  
因为 Hexo 会将 Stylus 渲染成 CSS 文件,所以此处为 modify.css。
增加插件脚本 由于用到 cheerio 来解析 HTML,所以需要先安装依赖。
新建一个文件,位于 scripts/modify.js,并增加以下内容。(此处只是举例,也可以使用已有的插件脚本文件。) 
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 (); }); 
大功告成 👏 恭喜你完成了修改,可以使用以下命令进行预览。
后记 其实早些时候,有篇最终效果类似的修改教程。@Nesxc  大佬写的「butterfly文章页美化教程 」。插件  系统实现的。
插件版的优点是更新主题时,只要结构变化不大,无需任何操作即可继续使用,并且管理更加方便。
如果像我一样,不想每次升级主题都可能要重新改一遍,或是为了方便管理,则可以选择插件版。