Categories: Мнение

Лучшая документация – это отсутствие документации

Выслушайте меня, прежде чем сказать, насколько я ошибаюсь.

За последние пару недель я прочитал несколько разных статей о написании хорошей пользовательской документации с точки зрения разработчика программного обеспечения. Это область, в которой мне всегда говорили, что я преуспеваю, от людей, которые читали документы, которые я писал на протяжении многих лет. Однако к тому времени, когда я ушел из своего более чем десятилетнего бизнеса WordPress, я почти полностью перестал писать пользовательскую документацию. Похоже, что немногие пользователи заметили или задались вопросом, почему нет пошаговых объяснений определенных функций.

Как и многие разработчики плагинов и тем WordPress, я твердо верю в наличие документации. Как человек, который занимается кодом с 2003 года, документация была моим лучшим другом. За свою карьеру я написал не менее нескольких сотен руководств или страниц документации. Я опубликовал две книги по развитию и был техническим редактором третьей. Я почти уверен, что создал один или два плагина с большим количеством встроенной документации, чем фактический код.

Однако я также поддерживал конечных пользователей более десяти лет. Я с уверенностью усвоил одну вещь: многие пользователи просто не читают документацию. Даже если бы они его читали, большую часть времени они не должны были нуждаться в этом.

Несмотря на то, что я повторяю, изменяя дизайн и пробуя свои силы во всем, чтобы вести пользователей к документации, прежде чем обращаться на форум поддержки с каждым вопросом, повторяющиеся вопросы никогда не перестают попадать в очередь поддержки каждый день.

Мне потребовались годы – намного больше, чем следовало бы, – чтобы понять, что решения нет в документации, и проблема не в способности пользователя прочитать его. Проблема была в продукте. Если пользователи задавали повторяющиеся вопросы, это означало, что с пользователем что-то не так. В конце концов я сместил фокус. Вместо того, чтобы писать больше документов, я сосредоточился на решении проблем, которые продолжали возникать в программном обеспечении.

Деятельность, в которой я потерпел неудачу, – это слушание.

Один из лучших навыков, который может получить разработчик, – это способность слушать, а затем переводить то, что говорят пользователи, в лучший код, пользовательский интерфейс и взаимодействие с пользователем.

В молодые годы – а я подозреваю, что многие разработчики были такими же, когда начинали – я чувствовал, что знаю ответ на каждый вопрос и всегда был прав. Я был высококвалифицированным специалистом и знал это. Для молодого 20-летнего разработчика это означает проблемы. Это означает, что вы считаете, что проблема не в том, что вы построили. Нет, проблема в том, что пользователь что-то делал не так. Это типы разработчиков, которые говорят «RTFM» и указывают пользователю на слишком технический документ, который не решает их проблемы.

Некоторые уроки усваиваются трудным путем, но мы должны их усвоить, чтобы создавать лучшие продукты.

Я обещаю, что если вы выполните одно действие – слушайте, действительно слушайте – пользователей, вы потратите гораздо меньше времени на объяснение того, как что-то работает. Вопрос, который вам нужно задать себе, заключается в том, зачем вообще должна существовать часть документации. Если для объяснения функции требуется 500 слов, велика вероятность, что эта функция не обеспечивает идеального взаимодействия с пользователем.

Создавая продукты, мы всегда должны стремиться создавать их так, чтобы не было необходимости в документации. Или, по крайней мере, сделайте их так, чтобы чтение руководства было последним средством решения проблем.

Для практических целей, как в прошлом штатный разработчик, я сохранил простой текстовый файл со списком повторяющихся вопросов. Это может быть более сложная настройка для команды, такая как создание проблем GitHub. Мой текстовый файл работал нормально, потому что я был шоу одного человека. Я бы взял за привычку регулярно просматривать список и спрашивать, как я могу улучшить каждый пункт. Некоторые предметы так и не вычеркнули из списка. Однако чаще всего я сначала извлекал важные уроки о создании для конечных пользователей. Я мог видеть вещи, которые имели смысл в моей голове, но сбивали с толку других.

Самые большие улучшения заключались не в поиске решений существующих проблем, а в распознавании проблем в новых продуктах, которые я создавал на основе прошлого опыта.

Со временем большая часть моей документации стала ориентирована на разработчиков. В основном это были учебные пособия по использованию API, хуков и других функций, связанных с разработчиком, – вещей, которые не были представлены через пользовательский интерфейс плагина. Я писал гораздо меньше для конечных пользователей, потому что обновлял проекты на основе их отзывов и вопросов. Да, время от времени я абсолютно терпел неудачу, но я становился все лучше и лучше тех, кто прислушивался к проблемам и вносил изменения, основываясь на том, что пользователи рассказывали мне по-своему.

Когда я говорю, что лучшая документация – это отсутствие документации, я не имею в виду, что вы должны полностью ее пропустить. Я хочу, чтобы вы задали вопрос, зачем нужна документация. Что вы можете сделать, чтобы упростить работу с пользователем? Вы активно отслеживаете вопросы службы поддержки и решаете их в самом продукте?

В процессе разработки мы часто говорим о написании «самодокументирующегося кода». Это способ сказать, что нужно писать код таким образом, чтобы вам не приходилось объяснять его другому разработчику через встроенную документацию. Например, wp_insert_post()функция в WordPress сообщает вам, что ее цель – вставить сообщение. Целью любого программного обеспечения также должно быть создание самодокументирующихся интерфейсов и других элементов, с которыми взаимодействует пользователь. Пользователи должны иметь возможность автоматически понимать назначение кнопки, текстового поля или флажка, не обращаясь к документации.

В следующий раз, когда вы сядете писать новую ориентированную на пользователя часть документации, убедитесь, что вы не используете ее как костыль для поддержки плохого взаимодействия с пользователем.

writer

Recent Posts

Плагин Delete Me для WordPress помогает владельцам веб-сайтов предоставить право на забвение GDPR

Поскольку до крайнего срока соблюдения GDPR ЕС осталось всего 178 дней , многие владельцы сайтов…

2 года ago

Команда Gutenberg наращивает юзабилити-тестирование в WordCamp US

Команда Gutenberg создаст станцию ​​тестирования удобства использования в WordCamp US, где посетители смогут принять участие…

2 года ago

Плагин распространителя теперь в бета-версии: новое решение для синдикации контента WordPress от 10up

Сегодня компания 10up опубликовала предварительную версию своего плагина Distributor , нового решения для синдикации контента…

2 года ago

Gutenberg 1.8 добавляет большую расширяемость для разработчиков плагинов

На этой неделе был выпущен Gutenberg 1.8 с несколькими заметными улучшениями, которые предоставят разработчикам плагинов…

2 года ago

Gutenberg 15.5 представляет экспериментальную поддержку разметки сетки

На этой неделе был выпущен Gutenberg 15.5 с новыми функциями и улучшениями возможностей полнофункционального редактирования…

2 года ago

DesktopServer 3.8.4 включает подарок сообществу

DesktopServer выпустил версию 3.8.4 своего программного обеспечения для локальной разработки. Эта версия включает в себя…

2 года ago