JavaScript

JavaScript, küçük dinamik bileşenlerden React veya Angular gibi bir JavaScript çerçevesinde çalışan tam ürünlere kadar neredeyse her şeyde önemli bir rol oynar.

JavaScript'in bu şekilde kullanılması (veya aşırı kullanılması), büyük miktarda kod nedeniyle uzun yükleme süreleri, anlamsal olmayan HTML öğelerinin kullanılması ve JavaScript aracılığıyla HTML ve CSS'nin eklenmesi gibi birçok endişe verici eğilimi ortaya çıkardı. Ayrıca erişilebilirliğin bu parçaların her birine nasıl uyduğundan emin olmayabilirsiniz.

JavaScript, sitenizin erişilebilirliği üzerinde büyük bir etkiye sahip olabilir. Bu modülde, JavaScript tarafından geliştirilen erişilebilirlik ile ilgili bazı genel kalıpların yanı sıra JavaScript çerçevelerinin kullanılmasından kaynaklanan erişilebilirlik sorunlarına yönelik çözümleri paylaşacağız.

JavaScript etkinlikleri, kullanıcıların web içeriğiyle etkileşime geçmesine ve belirli bir işlem gerçekleştirmesine olanak tanır. Ekran okuyucu kullanıcıları, ince motor becerileriyle ilgili sorunları olan kişiler, fare veya dokunmatik yüzeyi olmayan kişiler gibi pek çok kullanıcı web'le etkileşimde bulunmak için klavye desteğinden yararlanır. Bu kullanıcıların tümünü etkilediği için JavaScript işlemlerinize klavye desteği eklemeniz önemlidir.

Bir tıklama etkinliğine bakalım. <button> veya <a> gibi semantik bir HTML öğesinde onClick() etkinliği kullanılıyorsa bu etkinlik doğal olarak hem fare hem de klavye işlevini içerir. Ancak, genel bir <div> gibi anlamsal olmayan bir öğeye onClick() etkinliği eklendiğinde klavye işlevi otomatik olarak uygulanmaz.

Yapılmaması gerekenler:
<div role="button" tabindex="0" onclick="doAction()">Click me!</div>
Yapılması gerekenler
<button onclick="doAction()">Click me!</button>

Bu karşılaştırmayı CodePen'de önizleyebilirsiniz.

Bir tetikleyici etkinliği için anlamsal olmayan bir öğe kullanılıyorsa enter veya boşluk tuşuna basıldığını algılamak için bir keydown/keyup etkinliği eklenmelidir. Anlamsal olmayan öğelere tetikleyici etkinlikler eklemek genellikle unutulur. Maalesef bu işlem unutulduğunda, yalnızca fareyle erişilebilen bir bileşen ortaya çıkar. Yalnızca klavye kullanan kullanıcılar, ilişkili işlemlere erişemez.

Sayfa başlıkları

Belge modülünde öğrendiğimiz gibi, sayfa başlığı ekran okuyucu kullanıcıları için çok önemlidir. Kullanıcılara hangi sayfada olduklarını ve yeni bir sayfaya gidip gitmediklerini bildirir.

JavaScript çerçevesi kullanıyorsanız sayfa başlıklarını nasıl işlediğinizi göz önünde bulundurmanız gerekir. Geçişler veya yollar (sayfa değişiklikleri) sayfayı yeniden yüklemeyi içermediğinden bu, özellikle tek bir index.html dosyasından yüklenen tek sayfalık uygulamalar (SPA'lar) için önemlidir. Bir kullanıcı SPA'da yeni bir sayfa yüklediğinde başlık varsayılan olarak değişmez.

SPA'lar için document.title değeri manuel olarak veya yardımcı paketle (JavaScript çerçevesine bağlı olarak) eklenebilir. Güncellenen sayfa başlıklarını ekran okuyucu kullanıcılarına duyurmak biraz daha fazla çalışma gerektirebilir. Ancak dinamik içerik gibi seçenekleriniz de var.

Dinamik içerik

JavaScript'in en güçlü işlevlerinden biri, sayfadaki herhangi bir öğeye HTML ve CSS ekleme olanağıdır. Geliştiriciler, kullanıcıların işlemlerine veya davranışlarına göre dinamik uygulamalar oluşturabilir.

Web sitenizde veya uygulamanızda oturum açtıklarında kullanıcılara bir mesaj göndermeniz gerektiğini varsayalım. Mesajın beyaz arka plandan öne çıkmasını ve "Artık oturum açtınız" mesajını iletmesini istiyorsunuz.

İçeriği ayarlamak için innerHTML öğesini kullanabilirsiniz:

document.querySelector("#banner").innerHTML = '<p>You are now signed in</p>';

CSS'yi setAttribute ile benzer şekilde uygulayabilirsiniz:

document.querySelector("#banner").setAttribute("style", "border-color:#0000ff;");

Büyük güç büyük sorumluluk getirir. Maalesef HTML ve CSS'ye JavaScript ekleme özelliği, erişilemeyen içerikler oluşturmak için geçmişte kötüye kullanılmıştır. Yaygın olarak yanlış kullanılan bazı yöntemler aşağıda listelenmiştir:

Olası kötüye kullanım Doğru kullanım
Semantik olmayan büyük HTML parçalarını oluşturma Daha küçük semantik HTML parçaları oluşturma
Dinamik içeriğin yardımcı teknoloji tarafından tanınmasına zaman tanınmaması Kullanıcıların mesajın tamamını duymasına izin vermek için setTimeout() zaman gecikmesi kullanma
onFocus() için stil özelliklerini dinamik olarak uygulama CSS stil sayfanızdaki ilgili öğeler için :focus kullanın
Satır içi stillerin uygulanması, kullanıcı stil sayfalarının düzgün şekilde okunmamasına neden olabilir Tema tutarlılığını korumak için stillerinizi CSS dosyalarında tutun
Genel site performansını yavaşlatan çok büyük JavaScript dosyaları oluşturma Daha az JavaScript kullanın. CSS'de de benzer işlevleri (ör. animasyonlar veya yapışkan gezinme) daha hızlı ayrıştıran ve daha yüksek performanslı şekilde gerçekleştirebilirsiniz.

CSS için satır içi stil eklemek yerine CSS sınıflarını değiştirin. Bu, yeniden kullanılabilirlik ve basitlik sağlar. Sayfadaki gizli içeriği kullanın ve dinamik HTML için içeriği gizlemek ve göstermek üzere sınıfları değiştirin. Sayfanıza dinamik olarak içerik eklemek için JavaScript kullanmanız gerekiyorsa basit, öz ve tabii ki erişilebilir olduğundan emin olun.

Odak yönetimi

Klavye odak modülünde, odak sırasını ve gösterge stillerini ele aldık. Odak yönetimi, odağı ne zaman ve nerede kilitlemeniz gerektiğini ve ne zaman kilitlememenizi gerektiğini bilmektir.

Odak yönetimi, yalnızca klavye kullanan kullanıcılar için çok önemlidir.

Bileşen düzeyi

Bir bileşenin odağı düzgün şekilde yönetilmediğinde klavye tuşlarına takılmalar oluşturabilirsiniz. Klavye tuşlarını kullanan bir kullanıcı bir bileşende takıldığında veya odak olması gerektiğinde korunmadığında klavye tuzağı oluşur.

Kullanıcıların odak yönetimi sorunları yaşadığı en yaygın kalıplardan biri modal bileşendir. Yalnızca klavye kullanan bir kullanıcı modal pencereyle karşılaştığında, modal pencerenin işlevsel öğeleri arasında Sekme tuşuyla geçiş yapabilmelidir ancak modal pencereyi açıkça kapatmadan hiçbir zaman modal pencerenin dışına çıkmasına izin verilmemelidir. Bu odağı düzgün bir şekilde yakalamak için JavaScript gereklidir.

Yapılmaması gerekenler:
Yapılması gerekenler

Sayfa düzeyi

Kullanıcı sayfalar arasında gezinirken de odak korunmalıdır. Bu durum özellikle tarayıcının yenilenmediği ve tüm içeriğin dinamik olarak değiştiği SPA'larda geçerlidir. Kullanıcılar uygulamanızdaki başka bir sayfaya gitmek için bir bağlantıyı tıkladığında odak ya aynı yerde tutulur ya da tamamen başka bir yere yerleştirilir.

Sayfalar arasında geçiş yaparken (veya yönlendirme yaparken) geliştirme ekibi, sayfa yüklendiğinde odağın nereye gideceğine karar vermelidir.

Bunu yapmanın birden çok yolu vardır:

  • Odağı, aria-live duyurusu içeren ana kapsayıcıya yerleştirin.
  • Ana içeriğe atlamak için odağı bir bağlantıya geri getirin.
  • Odağı yeni sayfanın üst düzey başlığına taşıyın.

Odak noktanızı nereye koyacağınız, kullandığınız çerçeveye ve kullanıcılarınıza sunmak istediğiniz içeriğe bağlıdır. Bağlama veya işleme bağlı olabilir.

Durum yönetimi

JavaScript'in erişilebilirlik açısından kritik olduğu bir diğer alan da durum yönetimidir. Bu durum, bir bileşenin veya sayfanın mevcut görsel durumunun az gören, görme engelli veya sağır ve kör yardımcı teknoloji kullanıcısına aktarılmasında ortaya çıkar.

Bir bileşenin veya sayfanın durumu genellikle ARIA ve HTML modülünde açıklandığı gibi ARIA özellikleri aracılığıyla yönetilir. Bir öğenin durumunu yönetmeye yardımcı olmak için kullanılan en yaygın ARIA özelliği türlerinden birkaçına göz atalım.

Bileşen düzeyi

Sayfa içeriğinize ve kullanıcılarınızın ihtiyaç duyduğu bilgilere bağlı olarak, bir bileşenle ilgili bilgileri kullanıcıya aktarırken dikkate alınması gereken birçok ARIA durumu vardır.

Örneğin, kullanıcıya bir açılır menünün veya listenin genişletilmiş mi yoksa daraltılmış mı olduğunu bildirmek için bir aria-expanded özelliği kullanabilirsiniz.

Bir düğmeye basıldığını belirtmek için aria-pressed simgesini de kullanabilirsiniz.

ARIA özelliklerini uygularken seçici olmak önemlidir. Kullanıcıya hangi önemli bilgilerin iletilmesi gerektiğini anlamak için kullanıcı akışını düşünün.

Sayfa düzeyi

Geliştiriciler, ekrandaki değişiklikleri ve uyarı mesajlarını yardımcı teknoloji (AT) kullanıcılarına duyurmak için genellikle ARIA canlı bölgesi adlı görsel olarak gizli bir alanı kullanır. Bu alan, sayfanın tamamının yeniden yüklenmesi gerekmeden kullanıcıları sayfada yapılan dinamik değişikliklerden haberdar etmek için JavaScript ile birlikte kullanılabilir.

JavaScript, dinamik yapısı nedeniyle geçmişte aria-live ve uyarı bölgelerinde içerik yayınlamakta zorlandı. DOM'e içerik ekleme işleminin eşzamanlı olmaması, AT'nin bölgeyi algılamasını ve duyurmasını zorlaştırır. İçeriğin düzgün bir şekilde okunabilmesi için canlı veya uyarı bölgesi, yükleme sırasında DOM'da olmalıdır. Ardından metin dinamik olarak değiştirilebilir.

JavaScript çerçevesi kullanıyorsanız iyi haber şudur: Çerçevelerin neredeyse tamamında, tüm işi sizin yerinize yapan ve tamamen erişilebilir bir "canlı spiker" paketi bulunur. Canlı bir bölge oluşturma ve önceki bölümde açıklanan sorunlarla uğraşma konusunda endişelenmenize gerek yoktur.

Yaygın JavaScript çerçeveleri için bazı canlı paketler aşağıda verilmiştir:

Modern JavaScript, web geliştiricilerin güçlü web uygulamaları oluşturmasına olanak tanıyan güçlü bir dildir. Bu durum bazen aşırı mühendislik ve dolayısıyla erişilemeyen kalıplara yol açar. Bu modüldeki JavaScript kalıplarını ve ipuçlarını uygulayarak uygulamalarınızı tüm kullanıcılar için daha erişilebilir hale getirebilirsiniz.

Öğrendiklerinizi test etme

JavaScript bilginizi test edin

JavaScript ile bir öğenin stilini değiştirmenin en iyi yolu nedir?

Bir öğenin sınıfını değiştirmek ve stili CSS stil sayfanıza eklemek için JavaScript'i kullanın.
Doğrudan bir HTML öğesinde dinamik stil uygulamak için JavaScript'i kullanın.

Tüm JavaScript işlemleri klavye kullanıcılarını destekleyebilir mi?

Evet, ancak ek işlem yapmanız gerekebilir.
Hayır, yalnızca semantik HTML ile klavye kullanıcılarını destekleyebilirsiniz.
Evet, tüm işlemler klavye kullanıcılarını otomatik olarak destekler.