移动端适配完之后,在小屏幕上字体小于12px, 但实际按12px渲染,极限情况下可能导致布局错乱

问题说明

前提

假设UI给你的设计稿是750的,你本地开发也在750的浏览器视口下进行。

重现问题

假设你采用的rem方式适配,在750的设计稿上,有段文字的字体大小是20px,那么在375的浏览器视口下,理论上来说,这段文字的字体大小应该将被设置为10px,但chrome浏览器,最小字体大小为12px,即使你设置成了10px,那实际渲染的大小也是12px

会产生什么问题

  • 可能会影响布局

解决方案

  1. 优先与UI沟通,告知UI,浏览器最小字体为12px,小于12px的会按12px渲染,可能会导致布局出问题。让ui调整字体大小,以达到即使在375的视口大小下,依然保证最小字体为12px
  2. 如果平等沟通无效,应该尝试向上级反馈,将技术原理再重述一遍,再说明,一定要显示小于12px的字体,前端单独适配会增加大量的工作量。吃力不讨好。
  3. 如果前2步都无效,那就只能前端单独适配了。但记得要求增加工时,否则,你只能无偿加班了。

如何显示小于12px的字体

通过css的transfrom:scale(缩放倍数)来解决,但scale只是将显示效果缩放了,元素的实际占用空间并未改变,如果要连同实际占位空间也改变的话,那要在外部再套一层盒子,使这个套的盒子大小为缩放之后的预期大小,并将overflow设置为hidden

transform等比缩放后,实际占用空间修改_transform scale(10/24) 后 占位置如何处理-CSDN博客

最后

移动端项目开发前,尽量和ui约定好,最小视口宽度下(375px),最小字体应该是12px,最小边框宽度粗细应该是1px,最小尺寸应该是1px。这样能提前避免很多编码阶段的适配问题。

更确切的约束是

假定UI设计稿图是750px的,那么最小字体24px(因为在375px宽度的视口下,就变成了12px),最小边框应该是2px(因为在375px宽度的视口下,就变成了1px),最小尺寸应该是2px(理由和最小边框一致)

或者让ui直接给你375的设计稿。那最小字体应该是12px,最小边框宽度粗细应该是1px,最小尺寸应该是1px。就不用转换后再想一遍了。

参考资料

text-size-adjust - CSS:层叠样式表 | MDN (mozilla.org)

css3 - rem布局下,用户浏览器的最小字号是12px怎么办? - SegmentFault 思否

移动端rem小于12px文字-webkit-text-size-adjust - 知乎 (zhihu.com)

rem 前端字体_前端浏览器字体小于12px的解决办法-CSDN博客

解决前端浏览器字体小于12px办法-腾讯云开发者社区-腾讯云 (tencent.com)

相关推荐
NiceCloud喜云7 小时前
Opus 4.8 的 Effort Control 怎么选:Low 到 Max 五档策略
android·java·大数据·前端·c++·python·spring
wordbaby8 小时前
React Native + RNOH:跨页面数据回传的最佳实践与避坑指南
前端·react native
丷丩8 小时前
MapLibre GL JS第22课:查看本地GeoJSON
前端·javascript·map·mapbox·maplibre gl js
Front思9 小时前
AI前端工程师需要具备能力+
前端·人工智能·ai
ZC跨境爬虫11 小时前
跟着 MDN 学CSS day_29:(掌握文本与字体样式的核心艺术)
前端·css·ui·html·tensorflow
李子琪。12 小时前
网络空间安全深度实战:CSRF 漏洞原理剖析与基于 Token 的纵深防御体系构建(全栈实验报告)
前端·安全·csrf
冰暮流星12 小时前
javascript之history对象介绍
前端·笔记
IT_陈寒12 小时前
Vite热更新失灵?你可能漏了这个配置
前端·人工智能·后端
丷丩12 小时前
MapLibre GL JS第19课:实时更新要素
前端·javascript·gis·map·mapbox·maplibre gl js
Mr.Daozhi12 小时前
RAG 进阶实战:跑通 Demo 后我连续翻了 6 次车,逐一修复才真正可用(含 Gradio Web 版)
前端·数据库·langchain·大模型·gradio·rag·科研工具