用 flexbox 布局简历主体结构,移动端垂直堆叠、桌面端并排,配合断点控制字体、间距和图片尺寸,统一使用 rem 单位,完善打印样式与动效降级。

用 flexbox 布局简历主体结构,别碰 Float 和 table
响应式简历页面的核心是清晰的视觉流与断点控制,flexbox 能天然支持横向/纵向切换、对齐和顺序重排,而 float 在现代布局中已失效(尤其在 min-width 变化时容易塌陷),table 则语义错误且难以响应。
典型结构建议用三层嵌套:body → .container → .section(如 .header、.main、.sidebar)。移动端默认垂直堆叠,桌面端让 .main 和 .sidebar 并排:
.container { display: flex; flex-direction: column; } @media (min-width: 768px) { .container { flex-direction: row; } .main { flex: 3; } .sidebar { flex: 1; } }
- 避免给
flex子项设固定width,否则在小屏下会溢出;用flex比例或max-width控制伸缩边界 -
flex-wrap: wrap在简历里基本不用——内容长度可控,强行换行反而破坏模块完整性 - 注意
align-items默认是stretch,若侧边栏高度不一致,加align-items: flex-start防止拉伸
用 @media 控制字体、间距和图片尺寸,而不是重写整个布局
响应式不是“写两套 css”,而是渐进增强。字体大小、padding、margin 和头像 img 尺寸是最常随屏幕变化的三类属性。
推荐断点只设两个:768px(平板竖屏起)和 1024px(横屏或大屏),覆盖主流设备。不要为 iphone SE 单独写媒体查询——它会继承 768px 以下规则,足够清晰。
立即学习“前端免费学习笔记(深入)”;
@media (max-width: 767px) { h1 { font-size: 1.8rem; } .contact-item { margin-bottom: 0.5rem; } .profile-img { width: 120px; height: 120px; } } @media (min-width: 768px) and (max-width: 1023px) { h1 { font-size: 2.2rem; } .profile-img { width: 140px; height: 140px; } }
- 所有文字单位统一用
rem,根字号用html { font-size: 100%; }保证可访问性缩放生效 - 图片别用
width: 100%+height: auto粗暴拉伸,简历头像应保持比例,优先用Object-fit: cover裁切 - 避免在媒体查询里重复定义颜色、边框等静态样式——提取到基础选择器中
打印样式用 @media print 关闭无关元素,但保留语义结构
用户可能导出 pdf 或直接打印简历,此时轮播图、图标字体、阴影、背景色全要禁用,但不能删掉 h2、ul、time 这类语义标签——它们影响可读性和辅助工具解析。
@media print { * { box-shadow: none !important; text-shadow: none !important; } .no-print, .nav, .social-links { display: none !important; } body { font-size: 12pt; line-height: 1.4; color: #000; background: #fff; } a { color: #000; text-decoration: none; } img { max-width: 100% !important; height: auto !important; } }
- 不要用
display: none隐藏整段经历(比如.experience),这会让打印版简历空白——只隐藏装饰性容器 -
background-color和background-image必须显式设为transparent或none,否则某些浏览器打印时仍渲染 - 测试打印效果前,先在 chrome DevTools 的 Rendering 面板勾选
Emulate CSS media: print
用 prefers-reduced-motion 降低动画干扰,但别禁用所有过渡
简历不是动画演示页。用户开启“减少运动”系统偏好时,CSS 动画和过渡应弱化,但不能让交互完全僵硬——比如 hover 下划线、按钮轻微变色这类微反馈仍可保留。
关键原则:只对非必要动效做降级,且用 reduce 值判断,而非监听 js 事件。
@media (prefers-reduced-motion: reduce) { * { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01s !important; } /* 允许语义化过渡保留 */ a:hover { text-decoration: underline; } }
- 别在
@media (prefers-reduced-motion)里重置transform或opacity——这会导致元素突然跳变,反而更干扰 - 如果用了
scroll-behavior: smooth,也需在该媒体查询中设为auto,否则锚点跳转会卡顿 - 第三方图标字体(如 Font Awesome)的旋转动画(
fa-spin)必须被该规则捕获并停用,否则打印或低配设备上会持续闪烁
实际部署时最容易被忽略的是字体加载策略和 svg 图标 fallback:本地字体没加载完时,font-display: swap 能防止文字长时间空白,而 SVG 图标若用 引用外部 sprite,需确保路径在所有环境下都可访问——相对路径在子目录打开时会 404。