复杂应用大多情况下是偏专业和B端的一些UI界面,它们大多出现在桌面端使用环境,并且终端用户类型多样,涉及流程、链条、业务也大多呈现出多变复杂的特征。这篇文章,来自UX设计领域的顶级存在NNGroup,作者为凯特卡普兰。
我们之前将「复杂应用」界定为特定专业领域当中,需要经过广泛培训之后使用的,有着非结构化目标、非线性工作流程的任何应[ n 0 s j &用程序。这个k I ?概念可能听起来有点抽象,不过这么说你可能会 更容易理解:从科学研究到专业人员,诸如金融分析师,它们常用的那些专业软件应用。这类应用通常有着这些特点:
- 为有专业知识和训练有素的用户提供支持
- 帮助用户浏览、管理大型数据库,并提供高级的数据分析和处理的功能
- 通过可变和多样的基础任务功能来解决C n e问题或者达成目标
- 需要( F x ( *在多个角色、工具、平^ D i # e R台之间进行L P ! M ? r协作或者切换
- 可以用来减轻高影响力/高价值任务的风险,降低损失
尽管不同的复杂应用之间差异很大,但是他们的共同点是,专业的从业人员对于这类工具有着极强的依赖性。
考虑到设计师和开发者在面对这类工具的时候的挑战,我梳理总结了 8 个复杂应用的设计原则和指南。
很多研究表明,对于复杂的应[ # ? V ~ J用和工具,用b R h a : o ? s户更加青睐可以立刻上手开始使用而不受= z m S $ *它复杂度影响的那类工具。
与大量的教程W T U : 6 L、文档、帮助和设置说明相比,能够L R f 8立刻开始& s q x b的任务和项目,G ~ 3对于用户有着莫大的吸引力。这种现象被称为「活跃用户悖论」。
虽然在专业领A & } P域当中,倚靠k 7 * H @ 5摸索和^ 5 L v ] n 3 A 5试错学习是不恰当也不安全的,但是一定程度的边做边学是必须的,因为不可能在培训和手册当中涵盖! M n n P (所有的$ p u @ h使用场3 [ ) ( 1 J {景。
所以m [ ! 0 t J,在设计的时候应该提供「跳过教程」的直接上手的偏好设置,同时B s ; 3 $进行相应的安全性设置,避免新手的莽撞{ / v操作导致损失。比如可以限制这个阶Y 2 / g段的用户执行长流程多任务的操作,让控制面板实时显示操作结果或者预览结果,这样用户无需执行全部操作就可以知道大概的结果。
在 Salesforce 控制面板当中,就可以实时预览面板编辑的效果。
绝大多数用户都不是进阶的专家级用户,他们在绝N – w % ] @ !大多数时候会使用基础但是效率没那么高的操作和执行方案。很多用户形成习惯之后,通常不会主动做出改变,而这在日积月累之后导致大量的时间浪费,效率低下。
值得一提的是,这个时候依赖冗长的文档和教程其实很难达成效果,更合理的方式是结合用户所处的r 5 h P * T 2 p B上下文环境,通过界面工具提示的方式,适时地告知S L Q p J % q用户「有更高效方便的方法」。
通常,可以使用悬停提示,或者是弹出式工具提示来实现这一功能。
ArcMap 是一m K ;款地理信息系统类工具,它通常会通过上下文环境下的信息引导,来帮助用户了解技巧。
复杂的应用程序,通常会有很多功能是分散的而非线性的,不同的功能组合起来可以实现特定的功能。在这类工具当中,用户日常可能也不是很确切知道最终的目标是什么,而需要通过数据分析来逐步推进,同时,在知道确切目标的情况下,也应该可以遵循不同的路径灵活地达成目标。
设计师这些应用的时候,设计师应该避免使用固定、唯一、 僵化的实现路径,迫使用户必循严格按照某一固定路径来做r c B事情。一方面,允许用户跳过某个步骤,或者回滚到更早的路径,另一方面,允许用户遵循不同的方# N d J I % ~ !式和路径来达成目标。
比如万事达卡的自助服务就可以通过交互式的图表来引导用户完成不同的任务。
复杂的任务,通常意味着它需要很多步骤,不同的环节,而在实际的应用场景中,某个分析步骤耗费几个小时甚至几天,都是有可能的。在高度复杂的现实生活中,某个步骤可能会换人接手,可能会因! – F为硬件、 网络等问题而暂停甚至丢失,这也意味着「可追溯性」是很重要的。
所以,在这样的复杂应用当中,应该允许用户在使用过程中,可以便捷清晰地记录、保存、 导出内容和记录,允许用户中断_ w T ,中断后可以恢复特定的任务。在任务进行过程中可以进行注释? g Y、保存相关的说明。
在决策建模软件TreeAge 当中,用户可以在分析和建模过程中进行开放L 5 i c +式的注释,可以后续在底部快速访问c . L c – R $ .这些笔记。
复杂的应M c . b 4 # f用通常还会面) J s 3 %临一个状况,就是工具本身的不足,用户需要在多个工作空间上使用工具和内容的时候,它需要具备切换的功能。对于不具备的功能,应用程序应该允许使用第三方的应用来作为补充。
比如当软件不支持某个操作的时候,应该允许用户从线上的其他数据库中获取并导出数据来使用,可以依托外部文档作为支持,允许用户在应用中做注释和评论。
减轻工作负担的一个要点,e _ b 5 [是尽量使用通用的API、接口和标准,尽量兼容行业标准软件,比如 Excel、PP * / 0 ?owerpoint ,尽量使用标准格式,等等。
微软的商业分析软件 PowerBI 就提供了标准化的导出和复制功能,非常方便
复杂应用通常旨在保持泛用性。使用场景多样,多种不同的功能,一家汽车生产厂家,可能会和蜜蜂养殖机构采用同样的工具和软t n _ * 9件来监测机器故障。但是,这种泛用性的另外一面,就是混乱性。复杂的应用可能会同时兼顾到基础型^ 1 # H z的小白用户和进阶型的专家用户,而后者用到的功能很小概率会被基础用户用到。
所以,设计者需要在不降低功能性% F N的情况下,基于应用场景、 用户需求来进行简化和优化,在保持功能完整易用的前提之下,降低复杂度A z } x Z o和混乱度。
分阶段和层级展现就是一种降低a 4 % / @ g |混乱度但是不影响功能性的一种常见策略。当用户进行到特定任务+ n J r j ~ I、特定阶段、特等级别之后,再呈现特定功能,是有效的设计方法。
即使降低了混乱度,在复杂应用当中,[ o I P ^ R信息量可能依然是过载的。通常+ ` b u @ + z x Q,对于这种情况可以通过区分信息层级的主次来进行快速的区分,不过,从交互上来说,这可能依然不, f H C够。
对于诸如控制面板一样的界面,用户可能需要时刻查看面板上的信息,需要了解次级信息但是又不能离开界面,这就体现出主次信息之间的过渡呈现的重要性了。
一般而言,使用类似与悬停显示C 3 J _的方式,能够比较柔和地将次级信息呈现出来,允许用户查看详细的定量数据。下面这个案例当中就是,悬停显示更多次级信息。
复杂I 6 * ] I u I n应D ^ E w S用通常在界面上包含由大量的信息,而这个时候关键性的数据如果不在视觉上做突出显示M G 9 @ k,会被用户错过。通过视觉区分、提示警报的方式– t Q D H O ] a,让用户及时注意到,才有可能规避可能存在的问题。
值得注意的是x I Z 1 : s n,让关键信息和元素凸显的方式,并不一定非得是使用鲜艳的色彩和较粗的字体,简单的放大呈现,使用图形化的元素辅助提示,或者是提供足够的留白都可以达到目的,就像下面的案例一样:
结论
复杂的应用多种多样,支持的服务和功能也千差~ Q . h x Q ^万别,但是无论如何呈现,此类复杂应用的设计都是非常挑战设计师的设计功底的,需要设计师了解业务,了解用户,并且能够通过设计| F R K ( L更好地提供服务。
延伸阅读:
掌握这5大要素,你也能快速搞定极简设( Q n M K U e 0计风格
少即是多。极简主义的概念可以用这句足够极简的话进行总结。
阅读文章 >>
提升 UI 细节和体验的 10 个常用方法
如果你– Q b觉得你的 UI 设计起来# – Q H X k很无聊,想让它看起来更加有趣,其实是有很多u * % P ~ A d @相对通用的方法。这些方法大都不算复杂,稍加调整,总会有不俗的效果。
阅读文章 >>
UI设计师最常犯的10个错误,看看你有没有中招
编者按:做设计难免会出错。有的错误真的只是之前不知道,后知后觉遂有了恍然大悟。
阅T * g f n ? x T读文章 >>
想让交互更走心?这4种可见Z _ ; a X m P 状态微V E a 5 7交互技巧一定要学会
在经典的尼尔森十大启发式当中,「系统状态可见性」可以说是如今交互设计领域当中,最为重要的原则之一。通过向用户展现当前的状态,让用户拥有对系统的控制权,建立用户对于产品的信任感,这也是这种设计启发式的最重要的价值之一。
阅读文章 >>