← 全部指南

导航中的图标 vs 文字:何时使用哪一种(以及何时同时使用)

图标大小和点击区域:移动导航最低标准

为什么苹果的最低标准是44×44像素,谷歌的是48×48dp——以及图标大小如何影响移动转化率。

每天都会上演百万次这样的场景:购物者在手机上尝试点击商店页头的搜索图标,却没有点中,反而点到了logo,被送回首页。他们再试一次,又点错了,最后就离开了。商店老板查看分析数据,看到移动端的高跳出率,就怨声载道地责怪流量来源。真正的问题其实是一个只有28像素宽的图标——而人的大拇指可不会那么精准。

点击区域大小不是一个设计偏好问题。它是一个有直接收入影响的可衡量可用性因素,苹果和谷歌都根据对人类运动控制和触摸准确度的广泛研究发布了具体的最低要求。

快速阅读
  • 苹果要求点击区域至少44x44点(约7毫米)。谷歌要求48x48dp(约9毫米)。
  • 成年人手指指尖的面积覆盖8-10毫米——一个24像素的图标提供的面积还不到准确点击所需的一半。
  • WCAG 2.5.5(AAA级)规定最小值为44x44个CSS像素;WCAG 2.5.8(AA级,2.2版本新增)要求24x24个CSS像素加适当间距。
  • 在移动电商测试中,将导航点击区域从32像素增加到48像素使误点率下降了52%。

为什么是44像素和48dp

这些数字并非凭空而出。它们源自对人类手指解剖学和触摸屏准确度的研究。

麻省理工学院触摸实验室发表过这一领域最具基础性的研究之一。他们测量了数百名参与者的指尖接触面积,发现成年人的平均指尖面积在8–10毫米宽(贴在平面上时)。平均拇指面积甚至更大,为10–14毫米。在标准iPhone显示屏上(2倍Retina分辨率,163 PPI逻辑像素),44点等于约6.9毫米。在安卓设备上(mdpi密度),48dp等于约7.6毫米。

苹果在2007年的原始iPhone人机界面指南中将最低值设为44x44点,之后每个版本都保持不变。他们的测试表明,小于44点的目标会导致误点率大幅上升。指南中明确说道:”为交互元素提供充足的触摸目标。尽量保持所有控件的最小可点击区域为44x44 pt。”

谷歌通过自己的测试得出了稍大一些的最低值。Material Design规定48x48dp是最小触摸目标,相邻目标间至少相隔8dp。这在标准mdpi屏幕上转换为约9毫米——刚好在平均指尖范围内。

两个平台指南的关键见解是,可点击区域不一定要与视觉元素大小相同。 一个图标可以在24x24像素处渲染,但有一个48x48像素的可点击区域。图标周围的额外空间是看不见的,但在功能上是有效的。大多数精良设计的移动应用就是这样处理小图标的——视觉上很紧凑,但触摸目标则超出了它本身。

图标大小和点击区域之间的差距

理解图标大小(眼睛看到的)和点击区域大小(手指点到的)的区别对导航可用性至关重要。

大多数图标库——Phosphor、Feather、Material Symbols、Heroicons——默认以24x24像素渲染。这是一个不错的视觉尺寸。图标足够大,可以辨认,但又不会统治布局。但作为点击目标,24x24太危险了。它大约3.8毫米宽(标准显示屏)——还不到成年人平均指尖宽度的一半。

当视觉元素和点击区域都是同一个24x24像素时,会出现三个问题:

误点。 用户经常点中相邻元素而不是他们的目标。这在导航中特别有害,因为菜单项彼此靠得很近。导航上的误点不仅不能做用户想做的事——它还会把他们送到他们不想去的地方,这比根本没有反应更令人沮丧。

边缘点击。 即使用户点中了正确的目标,他们往往也只是点到了它的边缘。许多触摸实现只在精确的边界内才能注册点击。如果用户的手指落在24像素目标外2像素处,点击可能根本不会注册——或者可能触发了错误的元素。

无障碍排斥。 运动能力有障碍、有颤抖或精细运动控制能力下降的用户受到小点击区域的不成比例的影响。这同样适用于单手点击、边走边点击或在移动的公交车上点击的用户。WCAG 2.5.5(增强级)特别规定最小目标大小为44x44个CSS像素来解决这一问题,而较新的WCAG 2.5.8(在WCAG 2.2中以AA级引入)要求至少24x24个CSS像素加上与相邻目标的适当间距。

图标大小如何影响转化率

点击区域大小和转化率之间的联系不是理论性的。几家专注于电商的测试公司已经发布了相关数据。

谷歌移动用户体验研究团队的一项研究发现,将移动界面上的触摸目标从32像素增加到48像素可以将任务完成错误率降低52%。 虽然这项研究不是专门针对导航的,但其发现直接适用:更少的错误意味着更少的错误页面导航、更少的返回按钮点击、更少的放弃会话。

Baymard研究所关于移动电商可用性的研究发现,31%的移动电商网站在至少一个导航元素中的点击区域未能达到最低44像素指南。最常见的违规者是页头实用图标(搜索、购物车、账户)和产品列表页面上的过滤控件。

在一个详细的案例研究中,Baymard测试了一个中等规模时装零售商的移动网站,在将他们页头图标点击区域从30像素增加到48像素之前和之后进行了对比。结果是页头相关导航错误减少了15%,以及”乒乓跳转”现象有所改善,这是用户因为一直点错链接而快速前后导航的模式。

综合效应很明确:适当大小的点击区域可以减少导航层面的摩擦,让购物者留在走向购买的路径上,而不是因为沮丧而离开。

实用大小指南

这是移动设备上导航图标大小的直接参考表:

元素 图标视觉大小 最小点击区域 推荐点击区域 目标间距
标签栏图标 24–28 px 44x44 pt(苹果) 48x48 dp(谷歌) 最小8 dp
页头实用图标 20–24 px 44x44 pt 48x48 dp 8–12 dp
滑出菜单行 24 px图标 44 pt行高 56 dp行高(Material) 内置于行内距
浮动操作按钮 24 px图标 48 dp按钮 56 dp按钮(Material) 距边缘16 dp
过滤/排序控件 18–24 px 44x44 pt 48x48 dp 8 dp

如何在不放大图标的情况下创建更大的点击区域:

在CSS中,最简单的方法是添加内距。一个在按钮内以24像素渲染的图标,每边加12像素内距,会创建一个48像素的点击区域,同时保持视觉上的紧凑:

.nav-icon {
  width: 24px;
  height: 24px;
  padding: 12px;
  /* 总可点击面积:48x48px */
}

或者,在可点击元素上使用min-widthmin-height确保目标无论图标的视觉大小如何都能达到最小值:

.nav-icon-button {
  min-width: 48px;
  min-height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
}

为什么图标加标签自然解决点击区域问题

向导航图标添加文本标签的一个被低估的好处是,组合元素——竖直堆叠的图标上方加标签——自然会创建更大的点击区域,而不需要任何额外工作。

考虑一个标签栏项目,有一个24像素的图标和下方12像素的文本标签,间隔4像素。组合视觉高度是40像素。加上标准内距(顶部8像素,底部4像素),总可点击高度是52像素——超过了苹果和谷歌的最小值。宽度由文本标签决定,对于”Home”、”Search”或”Cart”之类常见导航词来说,通常是50–80像素。结果是一个大约60x52像素的点击区域——单个24像素图标的面积近乎翻倍。

这就是苹果和谷歌都推荐带标签标签栏的原因之一。标签不仅能提高理解度——它们通过创建更大的目标来改进触摸准确度。

测试你自己的点击区域

你可以在五分钟内审计你的商店的导航点击区域。

方法1:Chrome DevTools。 在Chrome中打开你的商店,按F12,切换到移动设备模拟器,启用”Show device frame”。导航到你的商店并查看你的标签栏或页头图标。在元素面板中,悬停在每个导航元素上,检查盒模型中的渲染大小。如果任何尺寸低于44像素,你就有问题了。

方法2:拇指测试。 在实际手机上打开你的商店。尝试使用拇指的平面垫点击每个导航项目——不要用指尖。如果你点不中、点错了,或者必须尝试两次,那这个目标就太小了。特别注意页头图标(搜索、购物车、账户),它们往往是大多数Shopify主题上最小的点击区域。

方法3:谷歌的Lighthouse。 在你的移动商店URL上运行Lighthouse审计。无障碍部分会标出点击区域太小或太接近的问题。查找”Tap targets are not sized appropriately”审计。

快速修复如果你的Shopify主题导航图标太小,在修改主题代码前先看看Navi+是否能帮助。菜单生成器默认生成符合点击区域标准的导航元素,图标大小和内距都可配置,开箱即可满足苹果和谷歌指南。

带有小点击区域的小图标是电商中最常见也是最容易修复的移动可用性问题之一。标准很清楚——苹果要求44像素最小值、谷歌要求48dp最小值、WCAG要求44像素——测试数据也一致表明,达到这些标准可以减少错误并改进转化。如果这周你对移动导航只做一件事,那就测量你的点击区域。

This article is part of the larger guide on Icons vs text in navigation: when to use which (and when to use both).

分享 Facebook X

开始使用 Navi+ AI Menu Builder

选择您的平台 — 免费安装,几分钟内上线。