Oleh isatrio - CC-by-SA 4.0 license
Dengan semakin kompleksnya kebutuhan untuk membuat situs web. Maka penggunaan tag HTML tidak lagi bisa sesederhana dahulu yang hanya menggunakan <div>
untuk segala jenis urusan. Waktu itu, kami perlu menambahkan id
atau class
, contoh: <div id="landmark" class="landmark">
.
Untungnya, saat ini untuk menulis kode yang berkaitan dengan tengaran (landmark) lebih dimudahkan sejak HTML5. Kita bisa menulisnya seperti contoh berikut <header>
atau <main>
.
Teknologi A11s (Aksesibilitas) dalam situs web sangat bergantung pada penggunaan tag HTML yang benar atau disarankan. Teknologi semacam pembaca layar akan membaca sesuai dengan urutan struktur HTML. Menstruktur tag HTML dengan baik akan sangat membantu teknologi ini.
Beberapa contoh kode tag HTML yang semantik yang seharusnya kita terapkan.
<header>…</header>
<nav>…</nav>
<main>…</main>
<article>…</article>
<aside>…</aside>
<footer>…</footer>
<button>…</button>
<!-- dan banyak lagi -->
Kita tidak boleh berhenti dengan semantik karena semantik tidak mencakup semua hal. Untuk beberapa hal kita harus menerapkan ARIA.
Polifil adalah kode untuk mengimplementasikan fitur dalam peramban yang belum mendukung fitur tersebut. Tapi dalam konteks A11s, maka polifil adalah teknologi tambahan untuk mendukung teknologi A11s. Salah satu contohnya adalah pembaca layar.
Sebagai contoh awal bentuk-bentuk ARIA bisa dilihat berikut di bawah
<!-- role -->
<nav role="navigation"></nav>
<!-- properties -->
<button aria-label="tutup">x</button>
<!-- states -->
<button aria-disabled="true">Tutup</button>
Tengaran adalah bagian-bagian tertentu dalam sebuah situs web. Seperti benda fisik yang kita lihat, tengaran dalam situs web dapat berupa <header>
, <nav>
, <footer>
, dan lain sebagainya. Beberapa contoh tengaran yang umum digunakan adalah sebagai berikut contoh di bawah.
<header role="banner"></header>
<main role="main"></main>
<aside role="complementary"></aside>
<footer role="contentinfo"></footer>
Tengaran ini untuk memudahkan pembaca layar untuk menavigasikan fokus elemen berdasarkan tengaran. Sehingga dengan mudah pembaca layar untuk menyebutkan ada dimana saya sekarang ini.
Membuat tengaran dalam setiap tag HTML kita itu penting. Tetapi dengan meletakan judul yang terstruktur itu akan membuat pengalaman navigasi yang lebih baik. Karena dalam navigasi pembaca layar ada opsi untuk langsung lompat ke bagian tengaran tertentu langsung menuju bagian yang ingin ditelusuri. Biasanya di awal sebuah situs web, ada bagian "lanjut ke konten" atau "skip to main content".
ARIA yang paling umum digunakan adalah aria-label
. Karena dalam penerapannya, developer hanya perlu menempatkannya sebagai atribut tambahan dalam elemen. Sebagai contohnya bisa dilihat sebagai berikut
<button arial-label="tutup">X</button>
<input id="name" name="name" aria-label="nama" required>
Dalam kasus di atas jika kita tidak menempatkan aria-label
maka element tersebut tidak akan dikenali sebagai label-nya. Hal itu akan sangat membingungkan jika kita berada dalam sebuah input tanpa instruksi.
aria-live
digunakan untuk tag HTML yang membutuhkan pembaruan konten. Sembulan (Pop up) adalah salah satu contoh untuk penggunaan aria-live
. Ada 3 jenis aria-live
yang bisa digunakan
<div aria-live="off"></div>
<div aria-live="polite"></div>
<div aria-live="assertive"></div>
Sedikit tambahan, aria-atomic
juga perlu untuk ditambahkan ke dalam tag HTML jika konten dalam aria-live
membutuhkan untuk diketahui oleh Assistive Tecnology
Penambahan atribut role="alert"
bisa juga ditambahkan untuk menandakan bahwa popup adalah juga sebagai tengaran.
Untuk memberi tahu pembaca layar bahwa input harus diisi, maka bisa menggunakan atribut aria-required="true"
atau cukup dengan atribut "required"
<input aria-required="true" required>
aria-hidden
Terkadang ada bagian tag HTML yang tidak perlu kita sebutkan atau tidak perlu di deteksi oleh pembaca layar. Tetapi dalam antar-muka masih dibutuhkan untuk ditampilkan. Biasanya hanya untuk hiasan atau tambahan informasi. Kita bisa menggunakan atribut aria-hidden
untuk keperluan ini.
<div aria-hidden="true"></div>
Agar tag HTML dapat terfokus dengan tab
, maka kita juga perlu untuk menambahka tabindex
dalam atributnya.
<div tabindex="0"></div>
<div tabindex="-1"></div>
Nilai 0 untuk navigasi tab secara bawaan. Nilai -1 untuk navigasi tab secara programatik menggunakan JS.
Salah satu atribut yang mungkin tidak banyak developer peduli adalah atribut tag HTML lang
. lang
adalah kependekan dari language, berfungsi sebagai pemberitahu kepada pembaca layar bahwa konten yang berada dalam tag HTML tersebut harus diucapakan dalam bahasa tertentu. Akan dijabarkan di contoh di bawah
<html lang="id">
<head>
<title>Contoh penggunaan lang</title>
</head>
<button>Tutup</button>
<button lang="en">Close</button>
</html>
"Tanpa ARIA itu lebih baik dari pada menggunakan ARIA sembarangan" - oleh RahmaUt