微信小程序:列表项上同样的css样式在IOS上字体大小不一样

一、问题描述

偶然看到一个奇怪的现象,在IOS上微信小程序的一个列表(

列表项应用了相同的CSS类),却出现了不同大小的字:

二、问题排查

1.Android设备及开发者工具显示正常

2.iPhone 6plus (IOS 12.5.7版本)显示正常

3.iPhone 12(IOS 16.3)版本显示异常(出现了不同大小的字)

原因分析: ‌

(1)Webkit 内核自动调整字体‌: iOS 的 Webkit 内核会根据容器宽度自动缩放字体,导致相同样式在不同容器中显示差异。

‌(2)单位使用不统一‌: 混合使用 px 和 rpx(如部分样式固定为 px),导致响应式适配失效。

(3)字体继承或覆盖问题‌: 未显式声明字体样式,部分文本节点继承了系统默认字体或父级容器的限制性样式47。

‌(4)媒体查询冲突‌: 不同屏幕尺寸的媒体查询未覆盖全部场景,特定分辨率下触发意外样式覆盖

由于是同一个列表,列表项使用了相同的css样式类,因此有可能是因为OS 的 Webkit 内核自动调整字体‌导致。

三、解决方案

在页面或者组件中禁用 Webkit 字体缩放:

复制代码
-webkit-text-size-adjust: none; /* 强制按实际字号渲染 */
相关推荐
晓得迷路了34 分钟前
栗子前端技术周刊第 98 期 - NPM 生态遭受攻击、Rspack 1.5.3、Storybook 10 beta...
前端·javascript·css
前端 贾公子42 分钟前
《Vuejs设计与实现》第 16 章(解析器) 上
vue.js·flutter·ios
Digitally10 小时前
如何将大型音频文件从 iPhone 发送到不同的设备
ios·iphone
Alice-YUE12 小时前
【css学习笔记8】html5css3新特性
css·笔记·学习
沐墨专攻技术13 小时前
二、网页的“化妆师”:从零学习 CSS
css·笔记·学习
吴Wu涛涛涛涛涛Tao14 小时前
Flutter 实现「可拖拽评论面板 + 回复输入框 + @高亮」的完整方案
android·flutter·ios
nodcloud16 小时前
点可云进销存商城如何部署在微信小程序
微信小程序·小程序
少年阿闯~~16 小时前
transition(过渡)和animation(动画)——CSS
前端·css·动画·过渡
Async Cipher16 小时前
CSS 继承 (Inheritance)
前端·css