neděle 13. srpna 2023

Využití rolí v html 5 - img srcset a img sizes, aria*

Příklady využití rolí a atributu srcset v HTML5:

  1. Využití rolí: Role v HTML5 pomáhají prohlížečům a asistivním technologiím lépe porozumět struktuře a významu jednotlivých částí stránky. Zde je příklad:
<header role="banner"> <h1>Moje webová stránka</h1> </header> <nav role="navigation"> <ul> <li><a href="#">Domů</a></li> <li><a href="#">O nás</a></li> <li><a href="#">Služby</a></li> <li><a href="#">Kontakt</a></li> </ul> </nav> <main role="main"> <article role="article"> <h2>Novinky</h2> <p>Zde jsou nejnovější zprávy ze světa.</p> </article> </main> <aside role="complementary"> <h3>Doporučené články</h3> <ul> <li><a href="#">10 tipů pro úspěšný web</a></li> <li><a href="#">Jak správně psát blogy</a></li> </ul> </aside> <footer role="contentinfo"> <p>&copy; 2023 Moje stránka. Všechna práva vyhrazena.</p> </footer>
  1. Atribut srcset pro obrázky: Atribut srcset umožňuje specifikovat různé zdroje obrázků pro různá zařízení a rozlišení obrazovky. To pomáhá zobrazit optimální verzi obrázku na základě zařízení, na kterém je stránka zobrazena. Zde je příklad:
<img src="obrazek.jpg" alt="Popis obrázku" srcset="obrazek-480w.jpg 480w, obrazek-800w.jpg 800w, obrazek-1200w.jpg 1200w" sizes="(max-width: 480px) 100vw, (max-width: 800px) 80vw, 1200px">

V tomto příkladu se obrázek obrazek.jpg zobrazí jako výchozí zdroj. Atribut srcset obsahuje různé verze obrázku pro různá rozlišení (480w, 800w, 1200w). Atribut sizes určuje, jak by se obrázek měl zobrazit na různých velikostech obrazovky.

Co znamená vw?

Jednotka vw v CSS znamená "viewport width" (šířka zobrazení). Tato jednotka měří část procenta šířky celého zobrazení (viewportu) daného zařízení. Velikost viewportu odpovídá šířce okna prohlížeče, a to bez ohledu na aktuální rozměry obrazovky.

Například:

  • 1vw = 1 % z celkové šířky viewportu
  • 50vw = polovina šířky viewportu
  • 100vw = 100 % šířky viewportu (což je plná šířka okna prohlížeče)

Takže, když ve vlastnosti sizes elementu obrázku použijete jednotku vw, stanovujete, jak velký by měl být obrázek vzhledem k šířce viewportu na různých velikostech obrazovky.


sizes="(max-width: 480px) 100vw, (max-width: 800px) 80vw, 1200px"

Tento kód určuje různé velikosti obrázku na základě šířky viewportu. Zde je jeho význam:

  • Pokud je šířka viewportu menší nebo rovna 480px, obrázek bude mít šířku 100vw, což znamená, že bude mít plnou šířku viewportu na malých zařízeních.

  • Pokud je šířka viewportu menší nebo rovna 800px (a zároveň větší než 480px), obrázek bude mít šířku 80vw. To znamená, že na středních zařízeních bude mít obrázek 80 % šířky viewportu.

  • Pokud šířka viewportu je větší než 800px, obrázek bude mít pevnou šířku 1200px.

Tato nastavení sizes umožňují definovat různé velikosti obrázku na různých zařízeních a velikostech obrazovek, což pomáhá optimalizovat zobrazení obrázků pro různé kontexty.

Provky aria-* pro přístupnost v html 5

Určení, že webové stránky jsou přístupné pro všechny uživatele, včetně těch se znevýhodněním, je důležitým cílem ve vývoji webu. K tomuto účelu byla do HTML5 zavedena řada prvků a atributů, které umožňují tvůrcům webů lépe popsat obsah a jeho význam, což usnadňuje nástrojům a technologiím pro přístupnost interpretovat a prezentovat obsah uživatelům s různými potřebami.

Atributy s názvem aria-* (Accessible Rich Internet Applications) jsou klíčovým prvkem, který byl přidán k HTML5. Tyto atributy umožňují vývojářům explicitně popsat různé části webového rozhraní, tak aby byly srozumitelné pro asistivní technologie, jako jsou čtečky obrazovky. Zde jsou některé z těchto atributů a jejich využití na příkladech:

  1. aria-label: Tento atribut umožňuje přidat textovou popisku k prvcům, které nemají dostatečně sémantický textový obsah. Například tlačítko, které má ikonu, může být označeno pomocí aria-label pro jeho popis.

  • <button aria-label="Otevřít menu"> <svg ...>...</svg> </button>
  • aria-labelledby: Tento atribut umožňuje odkazovat na existující elementy na stránce, jejichž obsah je vhodným popiskem pro cílový prvek.

  • <h2 id="section-title">Důležitá informace</h2> <div aria-labelledby="section-title"> ... </div>
  • aria-describedby: Tento atribut umožňuje odkazovat na existující elementy na stránce, které poskytují rozšířený popis pro cílový prvek.

  • <p id="help-text">Tento prvek je povinný</p> <input aria-describedby="help-text" ...>
  • aria-hidden: Tento atribut umožňuje skrýt prvky z asistivních technologií, které zpravidla předčítají obsah stránky.

  • <span aria-hidden="true"></span> Dokončeno
  • aria-role: Tento atribut definuje roli prvku v rámci stránky a pomáhá lépe popsat jeho funkci.

  • <nav aria-role="navigation">...</nav>
  • aria-live: Tento atribut definuje oblast, ve které se bude dynamicky aktualizovatý obsah hlasitě předčítat asistivními technologiemi.

    1. <div aria-live="polite" id="status">Aktualizace se provedla úspěšně.</div>

    Tyto atributy a mnoho dalších umožňuje vývojářům poskytnout bohatší informace o obsahu, což v konečném důsledku vede k lepší přístupnosti pro uživatele se znevýhodněním, jako jsou zrakové nebo sluchové postižení.

     

    Žádné komentáře:

    Okomentovat

    Jak zkopírovat styly jako font a odstavec v LibreOffice Write?

    V dokumentu Write píšu CV. Někde uprostřed mám nadpisy a chci zkopírovat jeden nadpis v četně stylů a vložit ho jinde. Když použiju např ct...

    Štítky

    .profile adm AI alfa transparence AND any aplikace asociativní pole atomicity audio awk bash benchmark bezpečnost biblehub BJT boolean buffering Cache-Conrol Cloudflare code Collector Cut-off colorpicker compare cookies css CSS3 curl cut čas data loss data lost data transfer reliability datasheet datetime.strptime development dioda diody EBO Emitter Cut-off Current ETag exclude exec Expires fflock fflush ffmpeg file read file write file_get_contents file_get_contents/file_put_contents file_put_contents filter find first_install.sh flock Fly-back dioda font-face fóra fotorezistor fread functions funkce fwrite gate gate drive geolokace gradient-background grep grub grub update hebrejština history hlavičky HS html html 5 https hudba charakterizace chroot ICES IGBT img sizes img srcset impedance implementace imshow inference inrush current install jalový výkon javascript javescript jednocení seznamů js kapacita součástek koeficient zesílení komunikace se serverem konfigurace Krita KSF Last-Modified lazy caching led LEFT JOIN librosa ligatury linux list log manuál masky matplotlib Max-Age measure memory měření MFCC MFCC koeficienty mint míry modules moralizace morphologie MOSFET mount moviepy mysql náběhový proud napěťová ochrana návod nel Network Error Logging NLP not nth-child oblékání ochrana okruhy přátel OpenVINO IR formát optočlen ořezové masky OSHB otázky otázky_jazyky otázky_moralismu_řešení parsování path personifikace photorec php php 4 php 5 php 6 php 7 php 8 phpbb phpBB3 pitch PN přechody pnp pole práva profilování program prune průraz přepěťová ochrana přepolování pseudokódd PWM regulátory pydub python python3 pytorch RBE RDSon read reaktance rectifier regulace vstupního napětí relyability remount replace restore reverzní geolokace RIGHT JOIN rm role rozvržení disků pro OS linux a data databází řešení samba sdílení Sec-Fetch-Dest Sec-Fetch-Mode Sec-Fetch-Site Sec-Fetch-User Secure Shell sed Set Cookie shunt schottka skript sloupce song sort soubory soundfile spínané zdroje spínání split SQL ssh stabilizace napětí stahování stream string strojové učení stropové učení syntax T5 tabulky tepelná ztráta test text-shadow thermal runaway time timestamp tkinter tr transistor transition tranzistor tranzistory tuple tvorba otázek TVS účiník update va charakteristika Vgs video Vth vynechání adresářů vývoj while wrapovací funkce XOR zdánlivý výkon zdroj zenerka zenerovo napětí zip zip archiv zkratky zpomalení zpracování textu Žalmy