百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

5个你不应该犯的可用性错误

zhezhongyun 2025-05-22 14:52 33 浏览

5个你不应该犯的可用性错误

5 Usability Mistakes You Shouldn’t Make

没有想打造糟糕用户体验的网页设计师。

糟糕的用户体验通常并不只有一个——大量微小的体验问题在整个用户界面中重复出现,最终汇聚成一种巨大的、让人讨厌的体验。

让我们学习一下那些会让你的用户讨厌的可用性错误。

1.忽视“空数据”时的页面设计(Neglecting the Design of Blank Slates

空白页(blank slate)是当用户没有添加任何数据,或者删除所有页面相关数据时他看到的页面。

让我们看看空白页的例子——FreshBook的项目估算(item estimates)界面:

FreshBooks的空白页面例子

我们可以看到他们是如何在空白页面放置一些简单的元素来大大加强了页面的可用性的。即:

  • 着重描述(Prominent description):在页面的顶端,有一个对该页面功能的明显描述。

  • 可交互组件(Actionable components):为用户提供三条途径进行交互操作,并能立即开始。

  • 空白页面指示(Blank slate indicator):为了不让人疑惑,页面提供了状态描述,告诉用户现在页面上没有数据。

让我们把这些空页面设计元素拿开,然后看看他们在可用性方面有多重要。

想象一下你自己是个初次访问上面这个页面的用户。你被卡住了,不知道在这个页面做什么,并且没有地方告诉你这个页面是干什么的(除非你要创建一个新项目,但你不确定你会创建出什么,并且创建结果是什么样)。

你在空白页面应该展示什么?

在最低限度上,你应该有一个空白页面指示(文字)。“没发现发票”,“还没有职位计划”,“没有要显示的图片”等等。

但是对于我来说,按最低限度提供空白页面指示说明还不够好。

如果你想告诉新用户在各种可能的情况下怎么使用你的软件,利用这些空白页面会是教导他们的绝佳机会。

2不清晰的按钮文案(Unclear Button Labels

当你在一款网页应用上填写完“创建一个账户”的表单后,结尾处的按钮应该显示什么(文案)?

它应该直观地显示“创建账户”。

像网页按钮这样的可交互界面元素的文案,应该总是和它将为用户做的事相呼应。这些界面元素不应该模糊、有疑问、引起歧义。它们应该足够明显。

让我告诉你这个想法是多么微妙。

看看下面这张图,它存在一个不清晰的按钮文案。

你可能会说:“这怎么不清晰了?很明显它说明了按钮的意图:联系我们。”

我说它不清晰是因为点击按钮后的结果并不明显:

  • 它会带我去一个新的网页么?例如:联系我们页?

  • 它会打开一个包含表单的模态网页窗口么?在表单里我可以输入信息。

  • 它会打开一个实时聊天插件让我能和一个真人聊天么?

事实上,以上情况都不是。

它会把你的默认邮件客户端打开:

为什么会这样?这里有一些可用性和用户体验问题:

  • 这么说会让人迷惑,我没想到我的邮件客户端会打开。

  • 如果我还没设置我使用的默认邮件客户端会怎么样?它就会打开操作系统默认的邮件客户端(就像微软的Outlook)?那只是在浪费我的时间

  • 如果我正在用别人的电脑,或者我正用我公司的电脑工作并且它没设置我的偏好,将会怎么样?

  • 如果我不知道网站会打开我的邮件客户端会怎么样?点击按钮后,如果邮件客户端刚打开,会弹出告警。这会吓我一跳

这个按钮的后续行为并不清晰。如果按钮上的文案是“给我发邮件”,然后打开我的邮件客户端,才会给人带来惊喜。

作为一个用户,我不应该花时间去观察网页内容,并以此来猜测按下按钮会发生什么事。为什么不干脆给我写出来?如果一个按钮上写着“保存”,我会强迫自己检查一下页面的其他部分,了解一下哪些内容会被保存下来。但如果写着“保存邮件”,那什么都清楚了。

当撰写按钮文案时,只要问一下这个问题就能帮你想出好的文案:“按下按钮之后会发生什么?”

这里有一些清晰文案的例子:

MailChimp注册表单

Ballpark上“创建一个新计时器 ”

GoGardless注册表单

想一个好的按钮文案是个简单快速的事儿,但有些人往往忽视这件事。

拥有清晰的按钮文案能极大强加(网站的)可用性。

3在没有给予任何反馈的情况下让用户等待

我讨厌等待。尤其是等待一段不明不白的时间。

如果我们一起开车在路上走——然后,你这个司机——把车开到路边,并且默默地坐了1分钟,也不告诉我为什么,我会对你很生气的。

但是,如果你说:“嘿,我需要在路边停一会儿,因为我困了,我需要休息一会儿。”那样我就会完全明白并耐心地等待。

在我们的网站和网页应用中 ,总会存在让用户等待的情况。

每当我们不定期升级网站内容、打开带有高分辨率图片的模态窗口,或者当我们的网站服务器突然性能下降时,我们都会让用户等待。

让用户等待有时是不可避免的。

但让用户等待——却并不告诉他为什么——并不是不可避免的。

不论是读取数据、更新内容,或者其他可能让用户等待的情况,都要告诉他们。

展示一个带有文字的进度条或者旋转动画,告诉用户正在发生什么。

Camera Plus上传进度条

Airbnb正在加载新内容

如果你的网站正在进行更新,告诉你的用户发生了什么:

苹果的公告页面

如果你让人们知道发生了什么,他们会对你的网站更有耐心的。

4在网页表单中丢失用户输入的数据

有一次,我在一个网站上注册。登录后,这个网站让我做的第一件事是填写我的个人信息。那没什么。

然后我选择了一张照片,填写一个或两个其他的输入框,并点击按钮提交我的信息。

当我回到同样的那个页面时我很吃惊,它告诉我需要填写更多的表单项。

但实际上我之前选择的照片消失了——我需要再一次选择照片并上传它。

这件事带给我的是网页表单验证的基本规则:不论你做什么,不要在验证我的输入信息后把它弄丢。

想象一下,如果你让用户花了很长时间填写表单,仅仅是因为她忘了填写一个输入框,她却不得不重新开始,这会让她多么泄气!

5可点击区域比它们显示出来的面积要小

确保外观上可点击的元素应该就是可点击的,这点很重要。

看看下面这张图就知道我想说什么了:

一个理性的用户会认为整个Tab页签都是可点击的,但在上面的例子却不是这样的。仅仅文字区域可点击,而不是整个页签。是的,我知道那很杯具。更糟糕的是,那是我所看过的普遍问题。

为什么会发生这种事?那是因为大部分网页设计师是用无序列表(<ul>)创建Tab导航菜单。那样的代码看起来是这样的:

<ul>

<li><a href=”">Link 1</a></li>

<li><a href=”">Link 2</a></li>

<li><a href=”">Link 3</a></li>

</ul>

这么写没啥问题。

而当设计师填写所有的样式属性(尤其是padding属性)到<li>上而不是<a>上(这才是样式应该起作用的地方)时,问题来了。

因为只有<a>元素可点击,我们想要它尽可能多地占用空间。

这意味着对于这种导航样式,几乎所有CSS都应该嵌入到<a>元素里面。

同样,当对链接赋予样式(不包括backgrounds或者borders)时,使用padding而不是margin。在Web元素中间时,Padding会实现和margin相同的空白效果,但会保持可点击区域的空间又大又舒服。

快速解决问题的办法(Quick Fixes

这里讲的大部分问题实际上都是很简单就能解决,所以如果你正在犯这些错误,现在就去解决它们。

如果你没有犯本篇文章中的错误,恭喜你!那你只需要保持用一双严格的眼睛观察你的用户界面,来抓住任何其他的可用性问题。

你的用户会感谢你的。

相关推荐

Python入门学习记录之一:变量_python怎么用变量

写这个,主要是对自己学习python知识的一个总结,也是加深自己的印象。变量(英文:variable),也叫标识符。在python中,变量的命名规则有以下三点:>变量名只能包含字母、数字和下划线...

python变量命名规则——来自小白的总结

python是一个动态编译类编程语言,所以程序在运行前不需要如C语言的先行编译动作,因此也只有在程序运行过程中才能发现程序的问题。基于此,python的变量就有一定的命名规范。python作为当前热门...

Python入门学习教程:第 2 章 变量与数据类型

2.1什么是变量?在编程中,变量就像一个存放数据的容器,它可以存储各种信息,并且这些信息可以被读取和修改。想象一下,变量就如同我们生活中的盒子,你可以把东西放进去,也可以随时拿出来看看,甚至可以换成...

绘制学术论文中的“三线表”具体指导

在科研过程中,大家用到最多的可能就是“三线表”。“三线表”,一般主要由三条横线构成,当然在变量名栏里也可以拆分单元格,出现更多的线。更重要的是,“三线表”也是一种数据记录规范,以“三线表”形式记录的数...

Python基础语法知识--变量和数据类型

学习Python中的变量和数据类型至关重要,因为它们构成了Python编程的基石。以下是帮助您了解Python中的变量和数据类型的分步指南:1.变量:变量在Python中用于存储数据值。它们充...

一文搞懂 Python 中的所有标点符号

反引号`无任何作用。传说Python3中它被移除是因为和单引号字符'太相似。波浪号~(按位取反符号)~被称为取反或补码运算符。它放在我们想要取反的对象前面。如果放在一个整数n...

Python变量类型和运算符_python中变量的含义

别再被小名词坑哭了:Python新手常犯的那些隐蔽错误,我用同事的真实bug拆给你看我记得有一次和同事张姐一起追查一个看似随机崩溃的脚本,最后发现罪魁祸首竟然是她把变量命名成了list。说实话...

从零开始:深入剖析 Spring Boot3 中配置文件的加载顺序

在当今的互联网软件开发领域,SpringBoot无疑是最为热门和广泛应用的框架之一。它以其强大的功能、便捷的开发体验,极大地提升了开发效率,成为众多开发者构建Web应用程序的首选。而在Spr...

Python中下划线 ‘_’ 的用法,你知道几种

Python中下划线()是一个有特殊含义和用途的符号,它可以用来表示以下几种情况:1在解释器中,下划线(_)表示上一个表达式的值,可以用来进行快速计算或测试。例如:>>>2+...

解锁Shell编程:变量_shell $变量

引言:开启Shell编程大门Shell作为用户与Linux内核之间的桥梁,为我们提供了强大的命令行交互方式。它不仅能执行简单的文件操作、进程管理,还能通过编写脚本实现复杂的自动化任务。无论是...

一文学会Python的变量命名规则!_python的变量命名有哪些要求

目录1.变量的命名原则3.内置函数尽量不要做变量4.删除变量和垃圾回收机制5.结语1.变量的命名原则①由英文字母、_(下划线)、或中文开头②变量名称只能由英文字母、数字、下画线或中文字所组成。③英文字...

更可靠的Rust-语法篇-区分语句/表达式,略览if/loop/while/for

src/main.rs://函数定义fnadd(a:i32,b:i32)->i32{a+b//末尾表达式}fnmain(){leta:i3...

C++第五课:变量的命名规则_c++中变量的命名规则

变量的命名不是想怎么起就怎么起的,而是有一套固定的规则的。具体规则:1.名字要合法:变量名必须是由字母、数字或下划线组成。例如:a,a1,a_1。2.开头不能是数字。例如:可以a1,但不能起1a。3....

Rust编程-核心篇-不安全编程_rust安全性

Unsafe的必要性Rust的所有权系统和类型系统为我们提供了强大的安全保障,但在某些情况下,我们需要突破这些限制来:与C代码交互实现底层系统编程优化性能关键代码实现某些编译器无法验证的安全操作Rus...

探秘 Python 内存管理:背后的神奇机制

在编程的世界里,内存管理就如同幕后的精密操控者,确保程序的高效运行。Python作为一种广泛使用的编程语言,其内存管理机制既巧妙又复杂,为开发者们提供了便利的同时,也展现了强大的底层控制能力。一、P...