اسکرول های قابل فوکوس روی صفحه کلید

از Chrome 124، اسکرول‌ها به‌طور پیش‌فرض قابل فوکوس کردن روی صفحه‌کلید هستند، در صورتی که کودکان قابل فوکوس روی صفحه‌کلید نداشته باشند.

زمینه

اسکرولرها همه جا هستند. ممکن است یکی را در کادر «شرایط و ضوابط» بیابید، جایی که باید تا انتها پایین بروید تا روی دکمه ارسال کلیک کنید. یا، ممکن است با یک نوار منوی عمودی پر از نمادها برای انتخاب روبرو شوید.

در چنین مواردی، بسیاری از کاربران وب از حرکات بالا به پایین ماوس یا صفحه لمسی خود برای پیمایش در سراسر عنصر استفاده می کنند. با این حال، دستگاه اشاره گر، پد لمسی یا صفحه لمسی راه بهینه هر کاربر برای پیمایش یک صفحه نیست. برخی از افراد ترجیح می دهند در صفحه HTML حرکت کنند و تنها با استفاده از صفحه کلید خود به هر عنصر قابل تمرکز دسترسی داشته باشند. این می تواند به دلایل مختلفی باشد. از افرادی که لرزش یا مشکلات دیگری دارند که کار کردن با ماوس را دشوار می‌کند، افرادی که در مکان یابی مکان‌نمای ماوس از نظر بصری مشکل دارند و سایرین که از یک سوئیچ یا کنترل صوتی استفاده می‌کنند.

بهترین شیوه‌های دسترس‌پذیری توصیه می‌کنند که همه ویژگی‌ها باید با استفاده از صفحه‌کلید در دسترس باشند. به این ترتیب، همه می توانند از وب به روشی استفاده کنند که بهترین کار را برای آنها دارد.

2.1.1 صفحه کلید: تمام عملکردهای محتوا از طریق یک رابط صفحه کلید بدون نیاز به زمان بندی خاص برای ضربه زدن به تک تک کلیدها قابل اجرا است، به جز مواردی که عملکرد زیربنایی به ورودی نیاز دارد که به مسیر حرکت کاربر بستگی دارد و نه فقط به نقاط پایانی. (سطح A)

قبل از این تغییر برای تمرکز در اسکرول

قبل از این تغییر، یک عنصر پیمایشگر فقط در صورتی می‌تواند روی برگه متمرکز شود که شاخص برگه به ​​صراحت روی 0 یا بالاتر تنظیم شده باشد. برای مثال از CSS و HTML زیر استفاده کنید. سپس، سعی کنید از اولین دکمه به عنصر اسکرول تب کنید.

div.scroll, button {
  border: 1px solid lightgray;
  margin-top: 1em;
  border-radius: 0.5em;
}

div.scroll {
  overflow: auto;
  width: 20em;
  height: 5em;
  display: block;
}
div.long {
  width: 10em;
  height: 10em;
}
<button>Start</button>
<div class="scroll" tabindex="0">
<p>This is a tab focusable scroller...</p>
<div class="long"></div>
<p>You need to scroll down to see this line.</p>
</div>
<button>End</button>
اسکرول به دلیل شاخص تب مثبت قابل فوکوس است.

با استفاده از یک tabindex منفی مانند HTML زیر، پیمایشگر نادیده گرفته می شود.

<button>Start</button>
<div class="scroll" tabindex="-1">
<p>This is not a tab focusable scroller...</p>
<div class="long"></div>
<p>You cannot see this line using the keyboard.</p>
</div>
<button>End</button>
اسکرول به دلیل یک شاخص تب منفی حذف شده است.

اگر مقدار tabindex را تنظیم نکنید، استفاده از پیمایش فوکوس متوالی برای دسترسی به اسکرول برای کاربر دشوار است. این می تواند برای کاربرانی که به ماوس دسترسی ندارند بسیار خسته کننده باشد.

<button>Start</button>
<div class="scroll">
<p>This scroller does not have a tabindex value set...</p>
<div class="long"></div>
<p>You cannot see this line using the keyboard.</p>
</div>
<button>End</button>
اسکرول هیچ فهرست برگه ای ندارد.

توجه داشته باشید که مانند HTML زیر، پیمایشی که شامل کودکان قابل فوکوس است، از قبل قابل دسترسی است، زیرا زمانی که کودکان قابل فوکوس متمرکز هستند، کلیدهای جهت دار امکان پیمایش را می دهند. هیچ رفتاری در این مورد تغییر نمی کند.

<button>Start</button>
<div class="scroll">
<p>This is a terms and conditions text. Please scroll down to acknowledge reading.</p>
<div class="long"></div>
<button id="B">Acknowledge</button>
</div>
<button>End</button>
اسکرول به دلیل داشتن کودکان قابل تمرکز قابل فوکوس است.

از کروم 124 با اسکرول های قابل فوکوس

این ویژگی به اسکرول‌های بدون تنظیم مقدار tabindex و بدون هیچ فرزند قابل فوکوس کردن امکان فوکوس با صفحه کلید را می‌دهد. این به کاربرانی که نمی‌توانند یا ترجیح می‌دهند از ماوس استفاده نکنند، اجازه می‌دهد تا با استفاده از برگه و کلیدهای پیکان صفحه‌کلید، محتوا را متمرکز کنند.

<button>Start</button>
<div class="scroll">
<p>This scroller does not have a tabindex value set...</p>
<div class="long"></div>
<p>but you can scroll through its content!</p>
</div>
<button>End</button>
اسکرول هیچ فهرست برگه یا فرزند قابل فوکوس پذیری ندارد اما همچنان قابل فوکوس است.

توجه داشته باشید که این رفتار فقط در صورتی اتفاق می‌افتد که پیمایش فرزند قابل تمرکز نداشته باشد. به عنوان مثال، اگر پیمایش قبلاً دارای یک دکمه باشد، فوکوس برگه از پیمایش رد می‌شود و مستقیماً روی دکمه تمرکز می‌کند. در این حالت، پس از فوکوس کردن دکمه، می‌توان از قبل با استفاده از کلیدهای جهت‌نما به محتوای پیمایش دسترسی داشت. با توجه به این قانون، در صورت وجود چنین کودکانی، پیش فرض ممکن است همیشه به بهترین شکل رفتار نکند. اگر می‌خواهید خود عنصر اسکرول در این شرایط قابل فوکوس روی صفحه‌کلید باشد، توصیه می‌شود مقدار شاخص تب 0 یا بالاتر را تنظیم کنید.

<button>Start</button>
<div class="scroll" tabindex="0">
<p>This is a terms and conditions text. Please scroll down to acknowledge reading.</p>
<div class="long"></div>
<button id="B">Acknowledge</button>
</div>
<button>End</button>
صفحه نمایش اسکرول 0 است.

این ویژگی به اسکرول‌ها اجازه می‌دهد تا در همه موارد به‌طور پیش‌فرض از صفحه‌کلید قابل دسترسی باشند، که به کاربران وب کمک می‌کند هنگام پیمایش برگه‌ها در صفحه، تجربه‌ای روان‌تر داشته باشند.