3个维度掌握Oh My CV:本地化Markdown简历构建指南
解决技术简历制作痛点的零配置实现方案
一、功能特性解析
如何通过微模块架构实现功能解耦? 📦
Oh My CV采用11个独立功能包实现模块化设计,每个包专注于特定功能领域。其中dynamic-css模块负责样式动态计算,front-matter处理Markdown元数据解析,gfonts-loader实现谷歌字体按需加载。各模块通过packages/utils/src/common.ts实现跨模块通信,这种架构使主题定制功能(site/src/components/edit/toolbar/ThemeColor.vue)可以独立迭代,不影响核心编辑功能。
如何实现浏览器内本地化简历编辑? 🔧
该工具核心优势在于完全浏览器内运行,所有数据存储在本地。关键实现位于site/src/utils/database.ts,通过IndexedDB API实现简历数据的持久化存储。编辑器组件(site/src/components/edit/Editor.vue)与预览组件(site/src/components/edit/Preview.vue)通过Vuex状态管理(site/src/composables/stores/data.ts)保持实时同步,实现"所见即所得"的编辑体验。
二、核心技术原理
简历渲染流程是如何实现的? ⚙️
简历渲染经历三个关键阶段:首先通过packages/markdown-it-katex/src/index.ts处理LaTeX公式,然后由packages/dynamic-css/src/index.ts生成动态样式,最后通过site/src/components/shared/ResumeRender.vue完成最终渲染。当用户修改字体设置时,信号通过style状态管理(site/src/composables/stores/style.ts)触发重新计算,整个过程基于Vue的响应式系统实现自动更新。
核心技术点:Oh My CV创新性地将Markdown解析、样式计算和PDF导出全部在浏览器内完成,无需后端服务支持,这使其可以完全离线运行。
配置优先级机制是怎样的? 📝
系统采用三级配置优先级:用户实时设置(最高)→ 简历文件元数据 → 全局默认配置。以字体设置为例,优先使用FontFamily.vue中用户选择的值,其次读取front-matter中的配置,最后fallback到site/src/utils/constants/default.ts定义的默认值。site/src/utils/index.ts中的getEffectiveConfig函数统一处理配置合并逻辑。
三、实战应用指南
如何定制个性化简历主题? 🎨
主题定制通过修改site/src/composables/stores/style.ts中的theme状态实现,主要包括三个维度:基础色板(--primary, --secondary等CSS变量)、排版系统(font-family, line-height)和布局参数(margin, padding, paper-size)。修改后通过site/src/utils/css.ts中的applyTheme方法实时注入到文档根元素,实现主题的即时切换。
如何实现PDF导出功能? 🖨️
PDF导出功能通过浏览器打印API实现,核心代码位于site/src/components/shared/ResumeRender.vue的generatePDF方法。该方法通过创建隐藏的打印样式表,临时调整页面布局,然后调用window.print()触发打印对话框。关键优化点在于site/src/assets/css/edit.css中定义的打印媒体查询样式,确保PDF输出效果与预览一致。
进阶技巧:通过修改
site/src/utils/constants/data.ts中的paperSizes配置,可以添加自定义纸张尺寸,满足特殊简历格式需求。
通过以上三个维度的解析,我们可以看到Oh My CV如何通过模块化设计、响应式状态管理和浏览器原生API,实现了一个功能完备的本地化简历构建工具。其核心价值在于将复杂的简历排版逻辑封装为简单易用的交互界面,同时保持了高度的可定制性,非常适合技术人员快速制作专业简历。
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0152- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
LongCat-Video-Avatar-1.5最新开源LongCat-Video-Avatar 1.5 版本,这是一款经过升级的开源框架,专注于音频驱动人物视频生成的极致实证优化与生产级就绪能力。该版本在 LongCat-Video 基础模型之上构建,可生成高度稳定的商用级虚拟人视频,支持音频-文本转视频(AT2V)、音频-文本-图像转视频(ATI2V)以及视频续播等原生任务,并能无缝兼容单流与多流音频输入。00
auto-devAutoDev 是一个 AI 驱动的辅助编程插件。AutoDev 支持一键生成测试、代码、提交信息等,还能够与您的需求管理系统(例如Jira、Trello、Github Issue 等)直接对接。 在IDE 中,您只需简单点击,AutoDev 会根据您的需求自动为您生成代码。Kotlin03
Intern-S2-PreviewIntern-S2-Preview,这是一款高效的350亿参数科学多模态基础模型。除了常规的参数与数据规模扩展外,Intern-S2-Preview探索了任务扩展:通过提升科学任务的难度、多样性与覆盖范围,进一步释放模型能力。Python00
skillhubopenJiuwen 生态的 Skill 托管与分发开源方案,支持自建与可选 ClawHub 兼容。Python0112