Переосмысление капчи: от легаси к инклюзивности

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

Разработка новой капчи на React позволила избавиться от легаси-кода и использовать UI-библиотеки, что упростило верстку и позволило дизайнерам вносить изменения без проблем. Был сделан акцент на инклюзивности, чтобы капча была доступна слабовидящим и незрячим пользователям.

Для обеспечения доступности была добавлена звуковая капча. Важным было правильно реализовать загрузку звуковой дорожки – только при воспроизведении, а не заранее. Также учитывалась работа со скринридерами. Семантическая вёрстка и атрибуты role и aria-label помогали скринридерам правильно воспринимать элементы.

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


Новое на сайте

19521Банковский троян VENON на Rust атакует Бразилию с помощью девяти техник обхода защиты 19520Бонобо агрессивны не меньше шимпанзе, но всё решают самки 19519Почему 600-килограммовый зонд NASA падает на Землю из-за солнечной активности? 19518«Липовый календарь»: как расписание превращает работников в расходный материал 19517Вредоносные Rust-пакеты и ИИ-бот крадут секреты разработчиков через CI/CD-пайплайны 19516Как хакеры за 72 часа превратили npm-пакет в ключ от целого облака AWS 19515Как WebDAV-диск и поддельная капча помогают обойти антивирус? 19514Могут ли простые числа скрываться внутри чёрных дыр? 19513Метеорит пробил крышу дома в Германии — откуда взялся огненный шар над Европой? 19512Уязвимости LeakyLooker в Google Looker Studio открывали доступ к чужим базам данных 19511Почему тысячи серверов оказываются открытой дверью для хакеров, хотя могли бы ею не быть? 19510Как исследователи за четыре минуты заставили ИИ-браузер Perplexity Comet попасться на... 19509Может ли женщина без влагалища и шейки матки зачать ребёнка естественным путём? 19508Зачем учёные из Вены создали QR-код, который невозможно увидеть без электронного... 19507Девять уязвимостей CrackArmor позволяют получить root-доступ через модуль безопасности...
Ссылка