最开始想的迁移方案是使用 skip-render 标记 html,但始终觉得不够优雅,因为导航栏、个人信息、头图之类的内容时常都会变,如果 skip-render 那永远都会是当时那个版本的页面,甚至可能超链接都是失效的,除了能显示原本的博文之外其实体验应该是相当差的——横竖感觉就是很突兀嘛!

直到今天突然意识到,hexo 渲染 markdown 为 html 文本肯定会分为三个大部分:

  1. 正文前部的各种元素,例如头图、导航栏、侧边栏等
  2. 正文的元素
  3. 正文后部的各种元素,例如版权、脚注等

一拍大脑, markdown 天生兼容 html 啊!!!

理论上对于 html 元素 hexo 应该不会过多插手渲染,那我不是理论上可以直接找到之前渲染好的 html 文件中的正文部分直接复制到 markdown 里面然后 hexo generate 就完成了?!

立马就开始动手实践,发现真的可以!

不过随着 butterfly 版本的迁移,页内标签外挂 tag 的渲染结果从 div-ul-li-button 变成了 div-button 的层级,原本在 li 上的类名现在转移到了 button 上,遂赶紧尝试使用正则批量替换。这里用了 <li class="tab([^"]*)">([\n\s]*)<button([^>]*)>([^<]*)</button>([\n\s]*)</li> 这个表达式在 VSCode 里搜索匹配,然后替换为 <button$3 class="tab$1">$4</button>

很快啊!刷的一下就全部都修改好了!!!

replace

然后再把原先的图片复制到现在的 img 目录下,批量改一手路径,Done!

谁能想到这个卡了我两年的问题,竟然能 15 分钟就搞定了!!!

过于激动,遂特写此文记录一下,真是拍大腿啊!!!