Не каждый, кто пользуется Интернетом сегодня, имеет такой же пользовательский опыт, как и обычный человек. Учтите следующее:
- Приблизительно 20 процентов населения США имеют определенный уровень инвалидности.
- В 2006 году Национальная федерация слепых (NFB) подала в суд на Target Corporation за неспособность предоставить доступ к их веб-сайту для покупок.
- Все веб-сайты, финансируемые государством, и многие компании, которые следуют хорошему корпоративному гражданству, обязывают веб-разработку следовать стандартным протоколам и разделу 508c соответствия Закону о реабилитации США.
Поэтому традиционно доступность относится к лицам с ограниченными физическими возможностями. В мире веб-разработок доступность также относится к доступности веб-контента в гораздо более широком смысле, включая, помимо прочего, все различные устройства с поддержкой Интернета, имеющиеся на рынке, все более старые (и будущие) версии этих устройств и системы, которые каталог и индексирование веб-контента.
К сожалению, многие владельцы и разработчики сайтов рассматривают доступность как стоимость и неудобства, которые не обязательно приводят к увеличению отдачи от инвестиций (ROI). Но что , если дизайнеры, разработчики и менеджеры проектов разработки подошел веб — сайт таким образом , что может ,обеспечить универсальный доступ к контенту, не тратя слишком много времени или денег? Стоит ли это того? В конце концов, зачем блокировать любого потенциального потребителя из-за физического недостатка, ограничений технологического устройства или требований к представлению сайта? Разве мы как общество не несем ответственности друг перед другом с точки зрения всеобщего и равного доступа к информации? Если не принимать во внимание философские аргументы, в этой белой книге на реальных примерах будет показано, как можно достичь скромного уровня доступности с помощью простых методов. В дополнение к базовым функциям специальных возможностей, которые всегда должны присутствовать на любой веб-странице (например, удобный для чтения с экрана параметр «переход к основному содержимому» и атрибуты ALT для изображений),методы, показанные ниже, будут учитывать обе интерпретации для обеспечения доступности способами, которые улучшают рентабельность инвестиций для любого веб-ресурса.
Семантические, иерархические структуры разметки
Один из наиболее важных методов разработки на стороне клиента для достижения «просветления» доступности включает в себя написание чистых, семантических структур HTML. Это легче сказать, чем сделать, конечно, учитывая, что HTML-таблицы на основе таблиц все еще широко распространены, несмотря на согласованные усилия по использованию макетов CSS.
По сути, вспомогательные технологии, такие как средства чтения с экрана, игнорируют * типичные ссылки на таблицы стилей, делают снимок объектной модели документа (DOM) и читают содержимое по порядку сверху вниз. Таким образом, правильно построенная иерархия контента предоставит более логичный пользовательский интерфейс для слабовидящих пользователей. Ключ заключается в том, чтобы обернуть содержимое семантически значимыми тегами HTML, которые описывают его роль (описательные теги), и избегать использования наиболее удобных тегов HTML для создания желаемого вида или позиции.
* В настоящее время W3C работает над стандартом для справки по ключевым словам CSS, удобной для чтения с экрана. Смотрите: [img_assist | nid = 2806 | title = | desc = | link = none | align = right | width = 465 | height = 368] http://www.w3.org/TR/css3-reader/
Например, при разработке нового веб-сайта для транзакционного банкинга Washington Mutual (WaMu) нашей задачей было разработать дальновидный пользовательский интерфейс, который обеспечивал бы все навороты для обычных веб-пользователей, уделяя при этом пристальное внимание созданию доступных структур HTML. Обратите внимание, что в примере справа (который показывает заголовок, отображаемый со стилями CSS и без них), мы использовали описательные теги для создания чистых неупорядоченных списков для групп ссылок и конструкций тегов семантической формы для поиска по сайту.
Семантические формы подачи
Правильно построенные формы отправки содержат собственный набор полезных HTML-тегов. К сожалению, они редко осуществляются из-за их относительной неизвестности. Они, однако, предоставляют огромное количество информации для нужд доступности. Мы использовали следующие три тега для улучшения семантического значения полей формы WaMu:
FIELDSET
FIELDSET тег, который должен быть использован только в сочетании с элементами формы, группы аналогичных наборов входных тегов под одной и той же оболочки. Это особенно полезно для длинных форм с несколькими наборами элементов поля. Поскольку тег fieldset является элементом уровня блока, его также можно использовать в качестве точки присоединения для стилей CSS и поведения JavaScript, что позволяет избежать таких проблем, как дивитит (практика использования слишком большого количества тегов DIV для визуализации компонента пользовательского интерфейса).
ЛЕГЕНДА
Легенда тег, который должен быть использован только в сочетании с Fieldset тега, определяет заголовок для полей. Для редизайна WaMu мы использовали CSS, чтобы скрыть тег легенды, чтобы мы могли создавать собственные метки для форм, зная, что это правильно определит набор полей для устройств, не относящихся к CSS.
МЕТКА
Элемент метки, возможно, является наиболее важным тегом, связанным с доступностью для форм. Он связывает текстовое описание с элементом ввода посредством сопоставления значений атрибута. С точки зрения взаимодействия с пользователем, это дает дополнительное преимущество применения фокуса к вводу при нажатии на метку.
В случае консоли входа в учетную запись для WaMu обычный веб-пользователь взаимодействует с расширенной формой DHTML (верхнее изображение), в то время как программа чтения с экрана все еще получает понятную модель взаимодействия (нижнее изображение), все из той же разметки. Окончательный HTML для формы входа WaMu включает один Fieldset , а легенду , описывающую содержимое FIELDSET и этикетки метки в паре с соответствующими входами.
Выгоды
[img_assist | nid = 2807 | title = | desc = | link = none | align = right | width = 244 | height = 351] Помимо предоставления вспомогательных технологий с логическими структурами контента, написание семантического HTML также улучшает SEO (поисковая оптимизация ) предоставляя контент, отформатированный в соответствии с его функциональной ролью. Например, теги заголовков H1, H2, H3 должны описывать заголовки разделов контента, чтобы поисковые пауки могли легко идентифицировать и индексировать их релевантность.
Другими бенефициарами семантической разметки являются различные типы интернет-устройств, таких как мобильные телефоны и КПК, которые не обязательно интерпретируют уровень представления так же, как традиционный настольный веб-браузер.
Масштабирование текста
Масштабирование текста необходимо для создания читабельного контента для людей с нарушениями зрения. Большинство людей с ограниченными возможностями по зрению обычно не являются полностью слепыми, но им нужно настроить размер текста на читаемый.
Большинство современных веб-браузеров оснащены функцией масштабирования текста как часть встроенного движка браузера. Самая большая проблема, стоящая перед дизайнерами и разработчиками пользовательского интерфейса, заключается в создании гибкого пользовательского интерфейса с компонентами, которые могут реагировать и корректироваться при увеличении или уменьшении размеров шрифта. Кроме того, производители браузеров до сих пор по-разному обрабатывали масштабирование текста, что усложняло управление им. Браузеры на основе Gecko (Firefox, Netscape и т. Д.) По умолчанию разрешают неограниченное масштабирование текста в любом направлении, в то время как Internet Explorer (версия 6) допускает только два уровня масштабирования в любом направлении (и только в том случае, если значения шрифта были установлены с использованием относительного измерения).Internet Explorer (версия 7) попытался облегчить проблемы с помощью алгоритма бикубической интерполяции, который не только увеличивает размер шрифта, но и все остальное на странице. Идея состоит в том, чтобы сохранить намеченный дизайн веб-страницы. Хотя IE7 не идеален (часто появляется горизонтальная полоса прокрутки), IE7 прошел долгий путь к удовлетворению потребностей пользователей в доступности.
Для редизайна WaMu клиент хотел увеличить масштабирование текста по умолчанию в браузере с помощью встроенного виджета масштабирования текста, который находится в правом верхнем углу пользовательского интерфейса. Этот подход кажется излишним, поскольку люди с требованиями к зрению знают, как использовать функцию масштабирования текста в браузере. Тем не менее, виджет отображается заметно на каждой странице и обеспечивает контролируемый подход, определяя, какие части страницы будут реагировать на масштабирование текста, сохраняя тем самым предполагаемый дизайн пользовательского интерфейса:
[Img_assist | NID = 2808 | название = | убывание = | ссылка = нет | Align = нет | ширина = 611 | высота = 422]
Выгоды
Очевидно, что основным преимуществом масштабирования текста является удобочитаемость. По словам Якоба Нильсона *, известного гуру юзабилити, пожилые люди — один из самых быстрорастущих сегментов пользователей Интернета. У них, как правило, есть деньги, чтобы потратить время на свои руки, и они могут испытывать трудности при передвижении. Этот архетипный веб-пользователь, как правило, нуждается в визуальной читаемости, связанной с возрастом. Удовлетворение этих потребностей может привлечь постоянных клиентов, которые ценят эти усилия.
* См. Http://www.useit.com/alertbox/high-roi.html.
Клавиатура навигации
Еще один отличный способ добавить доступ к веб-сайту, не разрушая банк, — это активно контролировать, как пользователь перемещается с помощью клавиатуры. Клавиша TAB чаще всего используется для перехода с одного предмета на другой. Вкладка обычно работает по умолчанию, начиная сверху, но может не следовать логическому пути, в зависимости от того, как устроена иерархия разметки.
В случае с WaMu мы назначаем определенный порядок TAB на страницах, которые могут иметь большое количество полей формы. Например, на странице «Оплатить счета и займы», где показана сводная информация обо всех получателях на банковском счете данного лица, пользователи могут вводить сумму платежа для каждого получателя. Мы присвоили атрибут TABINDEX динамически каждой строке получателя и еще более усилили идею, динамически применяя визуальную подсказку (серый фон) к каждой строке, когда пользователь перемещается вниз по странице:
[img_assist | nid = 2809 | title = | desc = | link = none | align = none | width = 573 | height = 243]
В таблице Pay Bills and Loans используется JavaScript для выделения фона строки, когда пользователь
нажимает на вход поле или использует клавишу TAB для навигации.
Другой пример управления клавишей TAB можно найти на консоли входа в учетную запись, где мы использовали JavaScript для активации раскрывающегося списка консоли (с фокусом, автоматически помещенным в первое поле), когда пользователь нажимает клавишу TAB в первый раз. Это позволяет пользователю войти в банковское приложение без необходимости использования мыши. Пользователь просто нажимает на вкладки, чтобы запустить раскрывающийся список, вводит свои учетные данные, просматривая каждое поле и, наконец, нажимает клавишу ВВОД, чтобы отправить форму. Используемая функция JavaScript проста:
function handleTab(evt) {
var e = evt || window.event;
if (e.keyCode == 9) {
if (getElementsByClass('form','loginbox')[0]) {
showLoginBox(getElementsByClass('form','loginbox')[0]);
}
if (getElementsByClass('input','usernamefield')[0]) {
getElementsByClass('input','usernamefield')[0].focus();
}
else if (getElementsByClass('input','passwordfield')[0]) {
getElementsByClass('input','passwordfield')[0].focus();
}
return false;
}
}
Прогрессивное улучшение, AJAX и валидация
Постепенное улучшение и постепенное ухудшение качества являются важными концепциями, которые учитывают доступность содержимого и функций веб-сайта в зависимости от возможностей агента пользователя (и самих пользователей). Главное, чтобы три уровня представления (HTML, CSS и JavaScript) были отделены друг от друга, чтобы веб-браузеры, которые могут использовать новейшие технологии, использовали их преимущества (прогрессивное улучшение), тогда как те, которые не могут, просто игнорируют или не получит их (изящная деградация). Таким образом, контент доступен каждому, независимо от того, какое устройство используется или требуется.
Проблема с AJAX
Недавние исследования показывают, что не существует стандартной методологии для создания доступных приложений AJAX. По сути, проблема заключается в неспособности многих программ чтения с экрана распознавать событие onreadystatechange (способ обработки асинхронных запросов к серверу в AJAX). Несколько обходных путей были предложены; однако ни один из них не работает одинаково для различных программ чтения с экрана и веб-браузеров на рынке.
Для тех, кто хочет попробовать реализовать доступное приложение AJAX, доступно несколько вариантов. Так как программы чтения с экрана делают снимок DOM и помещают его в виртуальный буфер, ключ к разработке способа информирования программы чтения экрана о том, что на странице произошло изменение.
- Используйте JavaScript для установки document.location = #response после получения responseText и обновления страницы. Эта опция работает только для некоторых программ чтения с экрана.
- Используйте JavaScript, чтобы установить response.focus () для измененного содержимого. Установите tabindex рассматриваемого HTML-элемента на -1, что позволяет фокусироваться на элементах, которые обычно не могут получать фокус. IE и Firefox поддерживают эту технику (Safari не поддерживает).
- Используйте JavaScript, чтобы поместить ответ в окно предупреждения : alert (request.responseText) . Этот метод работает для большинства программ чтения с экрана, но, очевидно, это довольно навязчивый подход. Один из обходных путей — предоставить браузерам программы чтения с экрана опцию флажка для получения ответов AJAX в окне предупреждений.
К сожалению, пока нет хорошего способа встроить доступность в AJAX-приложения, по крайней мере, единообразным и последовательным способом. Для получения дополнительной информации следующие три статьи точно описывают текущее состояние AJAX и доступность:
- AJAX и программы чтения с экрана: когда это может работать? Джеймс Эдвардс
- Заставить Ajax работать с программами чтения с экрана Gez Lemon и Steve Faulkner
- AJAX и средства чтения с экрана — вопросы доступа к контенту Стив Фолкнер
Проверка
Проверка кода играет важную роль в доступности. W3C предоставляет валидатор HTML, который весьма полезен для проверки синтаксиса. Однако одно из самых больших заблуждений относительно валидатора W3C заключается в том, что многие считают, что он также установит планку доступности. Правда заключается в том, что веб-страница, которая проверяется на соответствие валидатору W3C, не обязательно более доступна, и веб-страница недоступна, если она не проходит валидацию W3C.
Для правильных задач важно использовать правильные инструменты. Отличным (и бесплатным) онлайн-инструментом для проверки доступности является WatchXire WebXACT, который аналогичен валидатору W3C в том, что он сканирует исходный код веб-страницы, но дает результаты с критериями, которые в частности учитывают потребности в доступности и конфиденциальности.
Вывод
Как показано в этом техническом документе, доступность Интернета может быть достигнута с небольшими, но эффективными изменениями в методологиях разработки. Пока стандартизация между производителями программ чтения с экрана не станет более распространенной, как это было с производителями веб-браузеров, истинная доступность для Интернета останется движущейся целью. Между тем, все еще важно определить роль доступности в цикле разработки программного обеспечения с точки зрения ожиданий клиента и удовлетворенности конечного пользователя. Это требует участия не только разработчиков, но и дизайнеров пользовательского опыта, менеджеров программ и тестировщиков по обеспечению качества. Как и все успешные запуски веб-продуктов, работа в команде, общение,и понимание даст результаты, которые будут соответствовать традиционным потребностям доступности, обеспечивая доступность контента для максимального количества устройств и систем с доступом в Интернет.
об авторе
Как архитектор уровня представления, графический алхимик и специалист по веб-стандартам в Avenue A | Razorfish, опыт Фредерика Велтерлина и основные направления его работы включают в себя проектирование, разработку архитектуры и программирование шаблонов на стороне клиента, предоставление интерактивных и технических рекомендаций, а также разработку стандартов и процессов для лучших в своем роде веб-разработок. Фредерик имеет одиннадцатилетний опыт работы в качестве дизайнера и разработчика пользовательского интерфейса, отвечающего за концептуальную и практическую разработку дизайна для широкого спектра потребностей бизнеса и отрасли.