超实用干货!聊聊底部导航设计的四个关键原则

2016/08/12 6059

bottom-navigation-design-principle-1

@惜可若己 :设计师都知道设计绝不仅仅是做出外表好看的东西,设计还涉及到如何做才能让用户使用你的网站/应用程序。这项工作内容就像跟用户间对话一样,而导航就是对话内容之一。因为如果用户连他们究竟在哪儿都搞不清楚,那你的网站/应用程序设计得再棒又有什么用呢?来看这篇好文,帮你做出合格的底部导航设计!

如果你连基础都没打好,建议最好学习一下:《交互基础知识科普!带你认识最热门的12种导航模式》
如果想看深入的好文,可右戳直达:《交互设计实战!Tab导航与侧边抽屉导航的巅峰对决》

一、为何底部导航如此重要

Steven Hoover 在他的「用户究竟如何使用移动设备」的研究中发现,49%的人习惯于使用单个拇指来完成所有操作。在下图中,屏幕中不同颜色的区域表明用户拇指能够触及的难度等级,其中,绿色区域表示很容易触及的范围,黄色则表示拇指要伸展开来才能够到,而要触达红色区域则要求用户改变设备的手持方式。

dbdh20160812-1

△ 用户单手操作智能手机的区域图

这样看来,将顶级(经常使用的)功能放在屏幕的底部是非常重要的,因为这里是用户使用拇指能轻松跟设备产生交互的位置。

许多程序正是遵循上述原则,使用底部导航来表示程序中最重要的功能。Facebook便是代表之一,这样做也允许了用户能在不同功能间快速切换。

dbdh20160812-12

△ Facebook iOS客户端底部导航

二、底部导航设计的四个关键点

导航通常就是指引用户前往他们想去的地方的工具。底部导航则应该用来表示程序中常用的几项重要功能。这些功能要求能够直接从应用程序的任何地方访问。

好的底部导航设计遵循以下规则:

1、只显示最重要的功能

使用3-5个顶级导航标签。如果少于3个标签,考虑使用标签选项卡替代。

dbdh20160812-13

避免使用超过5个底部导航块,否则会造成块与块间显示太拥挤,也容易造成误点错点问题。另外,过多导航块会让你的程序看起来更加复杂。

dbdh20160812-2

如果你的顶层导航块确实超出了5个,不要都放在底部导航,考虑放在其他地方或选出最重要的放在底部。

2、避免使用滚动设计

对于小屏幕来说,隐藏一部分导航块显然是一个解决方案——你不用担心屏幕限制,只需要把导航块置于一个可滚动区域。但是这种方式难免会降低使用效率,因为即使你已经看到了你需要的块,你可能仍然需要滚动一下才能看到全部标签。

dbdh20160812-3

△ Rookie Cam iOS客户端滚动设计方案

3、告知用户当前位置

没有向用户表明其当前所在的位置大概是所有程序常常犯的一个错误。而对于用户,在成功地使用导航之前,他们要搞清楚的基本问题便是“我现在在哪”。

好的设计应该是用户在没有任何外界指引的情况下,也能仅靠第一眼就能知道该如何从A点到B点。你应该使用合适的视觉线索(图标、标签或者颜色)直观的告诉用户,而不必有任何多余的解释。

(1)图标

底部导航块往往都是使用图标表示,它们应该传达出跟其内容匹配的信息。虽然有一些用户熟知的通用图标,大多是用来代表诸如搜索、邮箱和打印等功能。不过这种通用图标非常稀少。但是程序设计者常常设计出从视觉样式很难识别出其对应的功能特性的图标。

dbdh20160812-4

△ Bloom.fm Android客户端之前的做法,用户很难理解自己当前的位置

(2)颜色

避免在底部标签栏使用不同颜色的图标和标签,应该使用程序的基本色调来突出当前所选标签。

dbdh20160812-14

△ 左:不同颜色的图标使你的程序像圣诞树 右:仅使用一种基本色调

请遵循一条简单的规则——给当前的选中标签使用程序的基本色调进行着色。

dbdh20160812-5

△ Twitter iOS客户端底部按钮

如果底部导航栏本身有颜色,应该使当前选中的图标和文本标签呈黑色或白色状态。

dbdh20160812-15

△ 左:避免在一个有色的底部导航栏使用不同颜色的图标 右:使用黑色或白色图标

(3)文本标签

文本标签应该是对导航功能的一个简短清晰的定义。应该避免使用太长的标签造成因被截取而显示不全或换行现象。

dbdh20160812-16

△ 避免文本标签换行、截取、压缩

素有标签元素应该很容易被用户看清楚。用户点击元素时他们应该清楚的理解要发生什么了。

(4)目标大小

应该使目标区域足够大能被轻易的触摸点击到。

Android设计规范建议底部导航栏遵从以下尺寸进行设计:

dbdh20160812-6

△ 手机上固定大小的底部导航栏

(5)标签上的标记符号

你可以在一个标签栏图标上显示一种标记符号来表明有与该视图或模式有关的新信息。

dbdh20160812-7

△ 使用标记符号与用户对话

4、使导航不言自明

优秀的导航设计就好比指导用户旅程的一只无形的手。毕竟,如果都不能别用户发现,那么即使最棒的功能或最能引人注目的内容也无法接触到用户。

(1)行为

每一个底部导航标签图标都必将带领用户到新的地方,可能不光光是打开一个菜单或是弹出框。点击一个底部导航标签时,应该直接带领用户前往相关的视图或者刷新当前活跃的视图。

kf20160812-1

不要使用标签栏给用户提供那些在当前屏幕/模式下发挥作用的控件元素,如果你想提供给用户控件,请使用工具栏。

dbdh20160812-17

△ iOS的工具栏

(2)争取一致性

尽可能在每种情况下显示相同的标签。这样的视觉稳定性对用户来讲是极好的。

不要在一个标签不起作用的时候移除它。如果你在某些情况下移除一个标签而在另一些情况下不这么做,这会使用户感知到的你的程序设计不稳定甚至不可预测。最好的方法是保持所有标签向用户开放,只不过如果某个标签下的内容不能用时要解释给用户。例如,如果一个用户并没有离线文件,Dropbox里的离线文件标签对应的屏幕告诉用户该如何使用离线文件。这个功能也叫做空状态处理。

dbdh20160812-9

△ Dropbox的空状态

(3)隐藏导航

如果屏幕内容是一个滚动式的信息流,标签栏可以在用户向上滚动加载新内容时隐藏,而在用户尝试向顶部回滚时重新显示。

dbdh20160812-10

△ 底部导航拦可以根据用户的滚动方向动态变化

(4)视觉愉悦

避免使用直接的横向运动来在不同视图间转换,不同视图间应该使用淡入淡出的动画来进行过渡。

dbdh20160812-11

△ 淡入淡出的动画

三、总结

底部导航应该:

可见且结构良好——使用3-5个标签栏并避免使用滚动式结构;

清晰的——标签栏应该易于浏览且尺寸足够大;

简单的——确保每个导航图标带领用户前往合适的地方,并保持包括底部导航在内的所有元素在整个程序中都具有一致性。

四、结论

帮助用户正确的导航应该是几乎每一个站点和应用程序中一件极为优先的事情。这种做法背后的目的是创建一个符合用户的自然心理模型的交互系统。

你是在为你的用户设计。多去考虑你的用户角色,想想他们在使用你的程序时的目标,而你正需要设计出合理的导航结构帮助他们实现目标。对他们而言,你的产品越容易使用,他们就越有可能真的去使用。

「技多不压身的设计师才有高薪资!」

  1. 平面设计:《超赞!设计师完全自学指南》
  2. 交互设计:《交互设计师修炼指南!教你从零开始成为优秀交互设计师》
  3. UI设计:《超实用新手指南!零基础如何自学UI设计?》
  4. 前端开发:《天猫高手来教你!零基础如何系统地学习前端开发?》
  5. 抠图技巧:《从菜鸟到高手!PHOTOSHOP抠图全方位攻略》
  6. 配色方案:《色彩搭配速成!3个实用方法帮你全面搞定配色》
  7. DPI指南:《基础知识学起来!为设计师量身打造的DPI指南》
  8. 交互设计自学路径图:《零基础入门!给非科班生的自学路径图之交互设计篇》

原文地址:uxplanet

yestone-uisdc-2

【优设网 原创文章 投稿邮箱:yuan@uisdc.com】

================关于优设网================
“优设网uisdc.com“是国内人气最高的网页设计师学习平台,专注分享网页设计、无线端设计以及PS教程。
【特色推荐】
设计师需要读的100本书:史上最全的设计师图书导航:http://hao.uisdc.com/book/
设计微博:拥有粉丝量160万的人气微博@优秀网页设计 ,欢迎关注获取网页设计资源、下载顶尖设计素材。
设计导航:全球顶尖设计网站推荐,设计师必备导航:http://hao.uisdc.com

非特殊说明,本文版权归原作者所有,转载请注明出处
本文地址:http://www.uisdc.com/bottom-navigation-design-principle

界面设计 HTML5 素材 交互设计师 好文 UI 用户体验设计 转场动效 设计师专访 设计师 排版布局 扁平化设计 设计规范 素材下载 视觉设计 职场 产品设计 设计趋势 配色 web前端开发 海报设计 AI教程 字体下载 设计理论 动效设计 神器下载 图标设计 psd下载 logo设计 神器推荐 ICON 职场规划 App设计 酷站推荐 字体设计 交互设计 ui设计 用户体验 设计师职场 优秀网页设计 酷站 ps技巧 PS教程 网页设计 经验分享
wechat

优设官方微信

50万设计师关注

微信号:youshege

把好文章收藏到微信

打开微信,扫码分享
学设计 优设网 在这里