Pentingnya urutan DOM default
Menggunakan elemen native adalah cara yang bagus untuk mempelajari perilaku fokus karena elemen tersebut secara otomatis disisipkan ke dalam urutan tab berdasarkan posisinya di DOM.
Misalnya, Anda mungkin memiliki tiga elemen tombol, satu per satu di
DOM. Menekan Tab
akan memfokuskan setiap tombol secara berurutan. Coba klik blok kode
di bawah untuk memindahkan titik awal navigasi fokus, lalu tekan Tab
untuk memindahkan fokus
melalui tombol.
<button>I Should</button>
<button>Be Focused</button>
<button>Last!</button>
Namun, penting untuk diperhatikan bahwa dengan menggunakan CSS, item dapat ada dalam satu urutan di DOM, tetapi muncul dalam urutan yang berbeda di layar. Misalnya,
jika Anda menggunakan properti CSS seperti float
untuk memindahkan satu tombol ke kanan,
tombol akan muncul dalam urutan yang berbeda di layar. Namun, karena urutannya dalam
DOM tetap sama, maka begitu pula urutan tabnya. Saat pengguna berpindah tab
di halaman, tombol akan mendapat fokus dalam urutan yang tidak intuitif. Coba klik
blok kode di bawah untuk memindahkan titik awal navigasi fokus, lalu tekan Tab
untuk
memindahkan fokus dari tombol-tombol.
<button style="float: right">I Should</button>
<button>Be Focused</button>
<button>Last!</button>
Hati-hati saat mengubah posisi visual elemen di layar menggunakan CSS. Hal ini dapat menyebabkan urutan tab berpindah-pindah, yang tampaknya acak, membingungkan pengguna yang mengandalkan keyboard. Karena alasan ini, checklist Web AIM menyatakan di bagian 1.3.2 bahwa urutan navigasi dan pembacaan, seperti yang ditentukan oleh urutan kode, harus logis dan intuitif.
Sebagai aturan, cobalah berpindah-pindah tab melewati berbagai laman sesering mungkin sekadar untuk memastikan Anda tidak secara tidak sengaja mengacaukan urutan tab. Ini adalah kebiasaan yang baik untuk diterapkan, dan tidak memerlukan banyak usaha.
Konten di luar layar
Bagaimana jika Anda memiliki konten yang saat ini tidak ditampilkan, tetapi masih harus berada di DOM, seperti navigasi samping yang responsif? Jika Anda memiliki elemen seperti ini yang menerima fokus saat berada di luar layar, mungkin terlihat seolah-olah fokus tersebut menghilang dan muncul kembali saat pengguna melakukan tab melalui halaman — jelas efek yang tidak diinginkan. Idealnya, kita harus mencegah agar panel tidak mendapat fokus saat berada di luar layar, dan hanya mengizinkan panel difokuskan saat pengguna dapat berinteraksi dengannya.
Terkadang Anda perlu melakukan sedikit pekerjaan detektif untuk mencari tahu sejauh mana fokus
berpindah. Anda dapat menggunakan document.activeElement
dari konsol untuk mengetahui elemen
mana yang saat ini difokuskan.
Setelah mengetahui elemen di luar layar mana yang sedang difokuskan, Anda dapat menyetelnya ke
display: none
atau visibility: hidden
, lalu menyetelnya kembali ke display:
block
atau visibility: visible
sebelum menampilkannya kepada pengguna.
Secara umum, kami mendorong developer untuk menelusuri situs mereka sebelum melakukan
publikasi untuk melihat bahwa urutan tab tidak menghilang atau keluar dari urutan
logis. Jika ternyata menghilang atau melompat, pastikan Anda telah menyembunyikan
konten di luar layar dengan benar melalui display: none
atau visibility: hidden
, atau apakah
Anda telah menyusun ulang posisi fisik elemen dalam DOM sehingga berada
dalam urutan logis.