--- title: 短文 - 博客迁移小记 date: 2024-10-13 20:35:27 tags: - 短文 - 博客 - 自言自语 categories: - 技术 --- 最开始想的迁移方案是使用 `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` 上,遂赶紧尝试使用正则批量替换。这里用了 `
  • ([\n\s]*)]*)>([^<]*)([\n\s]*)
  • ` 这个表达式在 VSCode 里搜索匹配,然后替换为 `$4` 很快啊!刷的一下就全部都修改好了!!! ![replace](/img/blog-mig/replace.png) 然后再把原先的图片复制到现在的 `img` 目录下,批量改一手路径,Done! 谁能想到这个卡了我两年的问题,竟然能 15 分钟就搞定了!!! 过于激动,遂特写此文记录一下,真是拍大腿啊!!!