从产品手册用户心理学分析到程序可用性与易用性的重要区别

注:机翻,未校对。


Designing for People Who Have Better Things To Do With Their Lives

为那些生活中有更重要事情要做的人设计

When you design user interfaces, it’s a good idea to keep two principles in mind:
在设计用户界面时,最好牢记两个原则:

  1. Users don’t have the manual, and if they did, they wouldn’t read it.
    用户没有手册,如果他们有,他们就不会阅读它。

  2. In fact, users can’t read anything, and if they could, they wouldn’t want to.
    事实上,用户无法阅读任何东西,如果他们可以阅读,他们也不会想要。

These are not, strictly speaking, facts, but you should act as if they are facts, for it will make your program easier and friendlier. Designing with these ideas in mind is called respecting the user, which means, not having much respect for the user. Confused? Let me explain.
严格来说,这些都不是事实,但你应该把它们当作事实来对待,因为它会让你的程序更容易、更友好。考虑到这些想法进行设计被称为尊重用户,这意味着对用户没有太多的尊重。困惑?让我解释一下。

What does it mean to make something easy to use? One way to measure this is to see what percentage of real-world users are able to complete tasks in a given amount of time. For example, suppose the goal of your program is to allow people to convert digital camera photos into a web photo album. If you sit down a group of average users with your program and ask them all to complete this task, then the more usable your program is, the higher the percentage of users that will be able to successfully create a web photo album. To be scientific about it, imagine 100 real world users. They are not necessarily familiar with computers. They have many diverse talents, but some of them distinctly do not have talents in the computer area. Some of them are being distracted while they try to use your program. The phone is ringing. WHAT? The baby is crying. WHAT? And the cat keeps jumping on the desk and batting around the mouse. I CAN’T HEAR YOU!
让一些东西易于使用意味着什么?衡量这一点的一种方法是查看现实世界用户在给定时间内能够完成任务的百分比。例如,假设程序的目标是允许人们将数码相机照片转换为网络相册。如果您让一组普通用户坐下来使用您的程序并要求他们全部完成此任务,那么您的程序的可用性越高,能够成功创建网络相册的用户百分比就越高。为了科学起见,想象一下 100 个现实世界的用户。他们不一定熟悉计算机。他们有许多不同的才能,但其中一些人显然没有计算机领域的才能。他们中的一些人在尝试使用您的程序时会分心。电话响了。什么?宝宝在哭。什么?猫不停地在桌子上跳来跳去,在老鼠周围拍打。我听不见!

Now, even without going through with this experiment, I can state with some confidence that some of the users will simply fail to complete the task, or will take an extraordinary amount of time doing it. I don’t mean to say that these users are stupid. Quite the contrary, they are probably highly intelligent, or maybe they are accomplished athletes, but vis-à-vis your program, they are just not applying all of their motor skills and brain cells to the usage of your program. You’re only getting about 30% of their attention, so you have to make do with a user who, from inside the computer, does not appear to be playing with a full deck.
现在,即使没有进行这个实验,我也可以自信地说,一些用户根本无法完成任务,或者需要花费大量时间来完成任务。我并不是说这些用户是愚蠢的。恰恰相反,他们可能是非常聪明的,或者他们可能是有成就的运动员,但相对于你的程序,他们只是没有将他们所有的运动技能和脑细胞应用到你的程序的使用中。你只能得到他们大约 30% 的注意力,所以你必须与一个用户凑合着玩,从计算机内部来看,他似乎没有玩完整的甲板。

Users Don’t Read the Manual. 用户不阅读手册。

First of all, they actually don’t have the manual. There may not be a manual. If there is one, the user might not have it, for all kinds of logical reasons: they’re on the plane; they are using a downloaded demo version from your web site; they are at home and the manual is at work; their IS department never gave them the manual. Even if they have the manual, frankly, they are simply not going to read it unless they absolutely have no other choice. With very few exceptions, users will not cuddle up with your manual and read it through before they begin to use your software. In general, your users are trying to get something done, and they see reading the manual as a waste of time, or at the very least, as a distraction that keeps them from getting their task done.
首先,他们实际上没有手册。可能没有手册。如果有的话,用户可能没有它,出于各种逻辑原因:他们在飞机上;他们使用的是从您的网站下载的演示版本;他们在家里,手册在工作;他们的 IS 部门从未给他们手册。坦率地说,即使他们有手册,除非他们绝对别无选择,否则他们根本不会阅读它。除了极少数例外,用户在开始使用您的软件之前不会紧紧抓住您的手册并通读它。一般来说,你的用户正在尝试完成一些事情,他们认为阅读手册是浪费时间,或者至少是一种干扰,使他们无法完成任务。

The very fact that you’re reading this book puts you in an elite group of highly literate people. Yes, I know, people who use computers are by and large able to read, but I guarantee you that a good percentage of them will find reading to be a chore. The language in which the manual is written may not be their first language, and they may not be totally fluent. They may be kids! They can decipher the manual if they really must, but they sure ain’t gonna read it if they don’t have to. Users do just-in-time manual reading, on a strictly need-to-know basis.
你正在阅读这本书的事实使你进入了一个由高文化程度的人组成的精英群体。是的,我知道,使用电脑的人基本上能够阅读,但我向你保证,他们中的很大一部分人会发现阅读是一件苦差事。编写手册的语言可能不是他们的第一语言,他们也可能不完全流利。他们可能是孩子!如果他们真的必须,他们可以破译手册,但如果他们没有必要,他们肯定不会阅读它。用户在严格需要知道的基础上进行即时手动阅读。

The upshot of all this is that you probably have no choice but to design your software so that it does not need a manual in the first place. The only exception I can think of is if your users do not have any domain knowledge — they don’t really understand what the program is intended to do, but they know that they better learn. A great example of this is Intuit’s immensely popular small-business accounting program QuickBooks. Many of the people who use this program are small business owners who simply have no idea what’s involved in accounting. The manual for QuickBooks assumes this and assumes that it will have to teach people basic accounting principles. There’s no other way to do it. Still, if you do know accounting, QuickBooks is easy to use without the manual.
所有这一切的结果是,您可能别无选择,只能设计您的软件,以便它首先不需要手册。我能想到的唯一例外是,如果你的用户没有任何领域知识 —— 他们并不真正理解程序的目的是什么,但他们知道他们最好学习。一个很好的例子是 Intuit 非常受欢迎的小型企业会计程序 QuickBooks。许多使用此程序的人都是小企业主,他们根本不知道会计涉及什么。QuickBooks 的手册假设了这一点,并假设它必须教人们基本的会计原则。没有其他方法可以做到这一点。不过,如果您确实了解会计,QuickBooks 无需手册即可轻松使用。

In fact, users don’t read *anything*.
事实上,用户什么都不读。

This may sound a little harsh, but you’ll see, when you do usability tests, that there are quite a few users who simply do not read words that you put on the screen. If you pop up an error box of any sort, they simply will not read it. This may be disconcerting to you as a programmer, because you imagine yourself as conducting a dialog with the user. Hey, user! You can’t open that file, we don’t support that file format! Still, experience shows that the more words you put on that dialog box, the fewer people will actually read it.
这听起来可能有点刺耳,但你会发现,当你进行可用性测试时,有相当多的用户根本不会阅读你放在屏幕上的单词。如果您弹出任何类型的错误框,他们根本不会阅读它。作为程序员,这可能会让您感到不安,因为您想象自己正在与用户进行对话。嘿,用户!您无法打开该文件,我们不支持该文件格式!尽管如此,经验表明,您在该对话框中输入的单词越多,实际阅读它的人就越少。

The fact that users do not read the manual leads many software designers to assume that they are going to have to educate users by describing things as they go along. You see this all over the place in programs. In principle, it’s OK, but in reality, people’s aversion to reading means that this will almost always get you in trouble. Experienced UI designers literally try to minimize the number of words on dialogs to increase the chances that they will get read. When I worked on Juno, the UI people understood this principle and tried to write short, clear, simple text. Sadly, the CEO of the company had been an English major at an Ivy League college; he had no training in UI design or software engineering, but he sure thought he was a good editor of prose. So he vetoed the wording done by the professional UI designers and added lots of his own verbiage. A typical dialog in Juno looks like this:
用户不阅读手册的事实导致许多软件设计人员认为他们将不得不通过描述用户来教育用户。你在程序中到处都能看到这一点。原则上,这没关系,但实际上,人们对阅读的厌恶意味着这几乎总是会给你带来麻烦。有经验的 UI 设计师会尽量减少对话框中的单词数量,以增加它们被阅读的机会。当我在 Juno 上工作时,UI 人员理解了这个原则,并试图写出简短、清晰、简单的文本。可悲的是,该公司的首席执行官曾是常春藤盟校的英语专业学生;他没有接受过 UI 设计或软件工程方面的培训,但他确实认为自己是一名优秀的散文编辑。因此,他否决了专业 UI 设计师的措辞,并添加了很多自己的措辞。Juno 中的典型对话框如下所示:

img

Compare that to the equivalent dialog from Windows:
将其与 Windows 中的等效对话框进行比较:

img

Intuitively, you might guess that the Juno version, with 80 words of instructions, would be “superior” (i.e., easier to use) than the Windows version, with 5 words of instructions. In reality, when you run a usability test on this kind of thing, you’ll find that
凭直觉,您可能会猜到具有 80 个单词说明的 Juno 版本会比具有 5 个单词说明的 Windows 版本 “更好”(即更易于使用)。实际上,当你对这种东西进行可用性测试时,你会发现

  • advanced users skip over the instructions. They assume they know how to use things and don’t have time to read complicated instructions
    高级用户跳过说明。他们假设他们知道如何使用东西,没有时间阅读复杂的说明
  • most novice users skip over the instructions. They don’t like reading too much and hope that the defaults will be OK
    大多数新手用户会跳过说明。他们不喜欢阅读太多,并希望默认值没问题
  • the remaining novice users who do, earnestly, try to read the instructions (some of whom are only reading them because it’s a usability test and they feel obliged) are often confused by the sheer number of words and concepts. So even if they were pretty confident that they would be able to use the dialog when it first came up, the instructions actually confused them even more.
    剩下的新手用户认真地尝试阅读说明(其中一些人只是因为这是一个可用性测试而阅读它们,他们觉得有义务)经常被大量的单词和概念所迷惑。因此,即使他们非常有信心能够在第一次出现对话框时使用该对话框,但这些说明实际上使他们更加困惑。

Now, Juno was obviously micro-managed beyond all reason. More to the point, if you’re an English major from Columbia, then you are in a whole different league of literacy than the average Joe, and you should be very careful about wording dialogs that look helpful to you. Shorten it, dumb it down, simplify, get rid of the complicated clauses in parentheses, and usability test. But do not write things that look like Ivy League faculty memos. Even adding the word “please” to a dialog, which may seem helpful and polite, is going to slow people down: the increased bulk of the wording is going to reduce, by some measurable percentage, the number of people who read the text.
现在,朱诺显然是超乎寻常的微观管理。更重要的是,如果你是哥伦比亚大学的英语专业学生,那么你的解读能力与普通人完全不同,你应该非常小心那些看起来对你有帮助的措辞对话框。缩短它,简化它,去掉括号里复杂的从句,以及可用性测试。但不要写看起来像常春藤盟校教师备忘录的东西。甚至在对话中添加 “请” 一词,这似乎很有帮助和礼貌,也会减慢人们的速度:增加的措辞量将减少阅读文本的人数,以某种可衡量的百分比。

Another important point is that many people are intimidated by computers. You probably know this, right? But you may not realize the implications of this. I was watching a friend try to exit Juno. For some reason she was having quite a bit of trouble. I noticed that when you try to exit Juno, the following dialog pops up:
另一个重要的一点是,许多人被计算机吓倒了。你可能知道这一点,对吧?但你可能没有意识到这其中的含义。我看到一个朋友试图离开朱诺。出于某种原因,她遇到了相当多的麻烦。我注意到,当您尝试退出 Juno 时,会弹出以下对话框:

img

She was hitting No, and then she was kind of surprised that Juno hadn’t exited. The very fact that Juno was questioning her choice made her immediately assume that she was doing something wrong. Usually, when programs ask you to confirm a command, it’s because you’re about to do something which you might regret. She had assumed that if the computer was questioning her judgment, then the computer must have been right, because, after all, computers are computers where as she was merely a human, so she hit “No.”
她打了 “不”,然后她有点惊讶朱诺没有退出。朱诺质疑她的选择这一事实让她立即认为自己做错了什么。通常,当程序要求您确认命令时,这是因为您将要做一些您可能会后悔的事情。她认为,如果计算机质疑她的判断,那么计算机一定是对的,因为毕竟计算机是计算机,因为她只是一个人,所以她打了 “不”。

Is it too much to ask people to read 11 lousy words? Well, apparently. First of all, since exiting Juno has no deleterious effects, Juno should have just exited without prompting for confirmation, like every other GUI program in existence. But even if you are convinced that it is crucial that people confirm before exiting, you could do it in two words instead of 11:
要求人们读 11 个糟糕的单词是不是太过分了?嗯,显然。首先,由于退出 Juno 没有有害影响,因此 Juno 应该像现有的其他 GUI 程序一样,在没有提示确认的情况下退出。但是,即使你确信人们在退出前确认是至关重要的,你也可以用两个词而不是 11 个词来做到这一点:

img

Without the completely unnecessary “thank you” and the remorse-inspiring “are you sure?“, this dialog is a lot less likely to cause problems. Users will certainly read the two words, say “um, duh?” to the program, and pound the Yes key.
如果没有完全不必要的 “谢谢” 和令人懊悔的 “你确定吗?”,这个对话不太可能引起问题。用户肯定会读到这两个词,对程序说 “嗯,呃?”,然后敲击 “是” 键。

Sure, the Juno Exit Confirmation dialog trips up a few people, you say, but is it that big a deal? Everyone will eventually manage to get out of the program. But herein lies the difference between a program which is possible to use versus a program which is easy to use. Even smart, experienced, advanced users will appreciate things that you do to make it easy for the distracted, inexperienced, beginner users. Hotel bathtubs have big grab bars. They’re just there to help disabled people, but everybody uses them anyway to get out of the bathtub. They make life easier even for the physically fit.
当然,Juno 退出确认对话框绊倒了一些人,但这有那么大不了吗?每个人最终都会设法退出该计划。但这就是可以使用的程序与易于使用的程序之间的区别。即使是聪明、有经验的高级用户也会欣赏您为分心、没有经验的初学者用户所做的工作。酒店浴缸设有大扶手。它们只是为了帮助残疾人,但无论如何,每个人都会用它们来摆脱浴缸。即使对于身体健康的人来说,它们也让生活更轻松。


via:

  • Designing for People Who Have Better Things To Do With Their Lives – Joel on Software

    https://www.joelonsoftware.com/2000/04/26/designing-for-people-who-have-better-things-to-do-with-their-lives/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/800213.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

微软Office PLUS办公插件下载安装指南

微软OfficePLUS插件下载安装指南 简介: OfficePLUS微软官方出品的Office插件 ,OfficePLUS拥有30万高质量模板素材,能帮助Word、Excel、Powerpoint、PDF等多种办公软件提升效率,具有智能化、模板质量高、运行快、稳定性强等优点。…

探索Facebook:数字社交的魔力源泉

在当今信息爆炸和全球互联的时代,社交媒体平台成为了人们生活中不可或缺的一部分。而在这些平台中,Facebook无疑是最具影响力和创新性的代表之一。自2004年成立以来,Facebook不仅改变了人们的沟通方式,更通过不断的技术创新和用户…

Pycharm与Gitlab交互

环境准备 1、下载配置好本地Git 2、配置Pycharm上的Git 3、gitlab账号 Gitlab配置 Gitlab配置中文 账号》设置》偏好设置》简体中文 创建项目 命令行操作 打开项目会展示以下步骤 在pycharm克隆gitlab的项目 通过菜单栏 1、在PyCharm的顶部菜单栏中,选择“V…

探索智能合约在金融科技中的前沿应用与挑战

随着区块链技术的发展和普及,智能合约作为其核心应用之一,在金融科技(FinTech)领域中展现出了巨大的潜力和挑战。本文将深入探讨智能合约的基本概念、前沿应用案例,以及面临的技术挑战和发展趋势,旨在帮助读…

R语言进行集成学习算法:随机森林

# 10.4 集成学习及随机森林 # 导入car数据集 car <- read.table("data/car.data",sep ",") # 对变量重命名 colnames(car) <- c("buy","main","doors","capacity","lug_boot","safety"…

昇思25天学习打卡营第11天|RNN实现情感分类

概述 情感分类是自然语言处理中的经典任务&#xff0c;是典型的分类问题。本节使用MindSpore实现一个基于RNN网络的情感分类模型&#xff0c;实现如下的效果&#xff1a; 输入: This film is terrible 正确标签: Negative 预测标签: Negative输入: This film is great 正确标…

SpringBoot之健康监控(Actuator)

1&#xff0c;基本介绍 Spring Actuator 是 Spring Boot 提供的一个扩展模块&#xff0c;用于监控和管理应用程序的生产环境。它通过 HTTP 端点暴露了大量的监控和管理功能&#xff0c;使得开发者可以在运行时查看应用程序的运行状况、配置信息、性能指标等。 主要功能&#…

【Qt】探索Qt框架:开发经典贪吃蛇游戏的全过程与实践

文章目录 引言项目链接&#xff1a;1. Qt框架的使用简介2. 贪吃蛇游戏设计2.1 游戏规则和玩法介绍2.2 游戏界面设计概述 3. 核心代码解析3.1 主界面&#xff08;GameHall&#xff09;3.1.1 布局和功能介绍3.1.2 代码实现分析 3.2 游戏选择界面&#xff08;GameSelect&#xff0…

WPF+MvvmLight 项目入门完整教程(一)

WPF+MvvmLight入门完整教程一 创建项目MvvmLight框架安装完善整个项目的目录结构创建自定义的字体资源下载更新和使用字体资源创建项目 打开VS2022,点击创建新项目,选择**WPF应用(.NET Framework)** 创建一个名称为 CommonProject_DeskTop 的项目,如下图所示:MvvmLight框架…

redis原理之底层数据结构(二)-压缩列表

1.绪论 压缩列表是redis最底层的结构之一&#xff0c;比如redis中的hash&#xff0c;list在某些场景下使用的都是压缩列表。接下来就让我们看看压缩列表结构究竟是怎样的。 2.ziplist 2.1 ziplist的组成 在低版本中压缩列表是由ziplist实现的&#xff0c;我们来看看他的结构…

uniapp 微信小程序根据后端返回的文件链接打开并保存到手机文件夹中【支持doc、docx、txt、xlsx等类型的文件】

项目场景&#xff1a; 我们在使用uniapp官方提供的uni.downloadFile以及uni.saveFile时&#xff0c;会发现这个文件下载的默认保存位置和我们预想的不太一样&#xff0c;容易找不到&#xff0c;而且没有提示&#xff0c;那么我们就需要把文件打开自己保存并且有提示保存到哪个…

fastadmin导入vue

前台 require-frontend.js或frontend-init.js 后台 require-backend.js或backend-init.js 后台 方法一 require-backend.js 在 paths 中加入’vue’:‘…/libs/vue/vue.min’, 在shim 中加入 paths: {............vue:../libs/vue/vue.min, } shim: {............vue: {ex…

acrobat 中 PDF 复制时不能精确选中所选内容所在行的一种解决方法

现象&#xff1a;划取行的时候&#xff0c;自动扩展为多行 如果整段选中复制&#xff0c;粘贴后是乱码 解决步骤 识别完&#xff0c;保存 验证 可以按行复制了。 如果遇到仅使用 acrobat OCR 不能彻底解决的&#xff0c;更换其他自己熟悉的进行 OCR。

小程序-模板与配置

一、WXML模板语法 1.数据绑定 2.事件绑定 什么是事件 小程序中常用的事件 事件对象的属性列表 target和currentTarget的区别 bindtap的语法格式 在事件处理函数中为data中的数据赋值 事件传参 &#xff08;以下为错误示例&#xff09; 3.事件传参与数据同步 4.条件渲染 …

three.js创建基础模型

场景是一个三维空间&#xff0c;是所有物品的容器。可以将其想象成一个空房间&#xff0c;里面可以放置要呈现的物体、相机、光源等。 通过new THREE.Scene()来创建一个新的场景。 /**1. 创建场景 -- 放置物体对象的环境*/ const scene new THREE.Scene();场景只是一个三维的…

如何安装node.js

Node.js Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行时环境。 主要特点和优势&#xff1a; 非阻塞 I/O 和事件驱动&#xff1a;能够高效处理大量并发连接&#xff0c;非常适合构建高并发的网络应用&#xff0c;如 Web 服务器、实时聊天应用等。 例如&#xff0c;在…

电脑远程开关机

1. 远程开机 参考&#xff1a;https://post.smzdm.com/p/664774/ 1.1 Wake On LAN - 局域网唤醒&#xff08;需要主板支持&#xff0c;一般都支持&#xff09; 要使用远程唤醒&#xff0c;有几种方式&#xff1a;使用类似向日葵开机棒&#xff08;很贵&#xff09;、公网ip&…

车载音视频MediaPlayer优化方案

媒体播放现状 从手机到车载&#xff0c;在很多地方还是有很大的不同。针对多媒体的场景Android车机目前大部分结构大致结构如下图&#xff1a; 从以上图看出的问题&#xff1a; 各个音视频APP单独实现播控界面&#xff0c;播放链路不一致&#xff0c;使用的底层播放器和音频焦…

书生大模型实战入门:Git

任务1: 破冰活动&#xff1a;自我介绍 任务2: 实践项目&#xff1a;构建个人项目 任务1: 破冰活动&#xff1a;自我介绍 VSCODE下载Git插件&#xff1a; 打开Github&#xff1a;https://github.com/InternLM/Tutorial&#xff0c;新建分支&#xff08;Fork&#xff09; 创建后…

在VS2017下FFmpeg+SDL编写最简单的视频播放器

1.下载ShiftMediaProject/FFmpeg 2.下载SDL2 3.新建VC控制台应用 3.配置include和lib 4.把FFmpeg和SDL的dll 复制到工程Debug目录下&#xff0c;并设置调试命令 5.复制一下mp4视频到工程Debug目录下&#xff08;复制一份到*.vcxproj同一目录&#xff0c;用于调试&#xff09; 6…