abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 13:22 | IT novinky

    Společnost OpenAI, která stojí za chatovacím robotem s umělou inteligencí (AI) ChatGPT, získala od investorů 122 miliard USD (2,6 bilionu Kč). Hodnota společnosti tak dosáhla 852 miliard dolarů (více než 18 bilionů Kč). Nejnovější kolo investování se stalo největší, jaké zatím firma uskutečnila, a peníze mají posílit ambiciózní plány rozšíření výpočetní kapacity, datových center a nábor talentů.

    Ladislav Hagara | Komentářů: 0
    dnes 13:11 | IT novinky

    Nástroj k identifikaci občanů v on-line komunikaci s úřady byl dnes dopoledne zhruba dvě hodiny částečně nedostupný. Problém se objevil kolem 09:00 a podařilo se ho vyřešit kolem 11:00. Částečně nedostupná byla služba Národní identitní autority (NIA), problémy podle DIA (Digitální a informační agentura) ovlivňovaly přihlašování například i přes bankovní identitu. „Dostupnost NIA byla plně obnovena, přihlášení k digitálním službám

    … více »
    Ladislav Hagara | Komentářů: 0
    dnes 13:00 | IT novinky

    Eben Upton oznámil další zdražení počítačů Raspberry Pi kvůli růstu cen pamětí a představil Raspberry Pi 4 s 3 GB RAM za 83,75 dolarů.

    Ladislav Hagara | Komentářů: 0
    dnes 04:33 | Humor

    Anthropic patrně omylem zveřejnil celý zdrojový kód svého CLI nástroje Claude Code prostřednictvím přiloženého sourcemap souboru v npm balíčku. Únik odhalil doposud nijak nezveřejněné funkce jako je například režim v utajení, autonomní agent 'KAIROS', orchestrace multi‑agentů, režim snění nebo dokonce virtuální mazlíček Buddy. Zajímavostí je detekce naštvání uživatele pomocí obyčejného regexpu. Anthropic rychle odstranil sourcemap a vydal opravu, nicméně kopie kódu se již stihly na GitHubu rozšířit mezi prostým lidem.

    NUKE GAZA! 🎆 | Komentářů: 8
    včera 14:33 | Humor

    Copilot automaticky vkládal do pull requestů 'propagační tipy', reklamní text se na GitHubu objevil ve více než jedenácti tisících pull requestech. Po vlně kritiky byla tato funkce zablokována a produktový manažer Tim Rogers připustil, že umožnit Copilotovi upravovat cizí pull requesty bez vědomí autorů byla chyba.

    NUKE GAZA! 🎆 | Komentářů: 4
    včera 12:55 | Upozornění

    Je 31. března a tedy Světový den zálohování (World Backup Day). Co by se stalo, kdyby Vám právě teď odešel počítač, tablet nebo telefon, který používáte?

    Ladislav Hagara | Komentářů: 4
    včera 12:44 | Upozornění

    Digitální a informační agentura (DIA) přistupuje ke změně formátu důvěryhodného seznamu České republiky z verze TLv5 na verzi TLv6, která nastane 29. dubna 2026 v 00:00 (CET). Ke změně formátu důvěryhodných seznamů členských států (tzv. Trusted Lists) dochází na základě změn příslušné unijní legislativy. Důvěryhodné seznamy se používají v rámci informačních systémů a aplikací zejména pro účely ověřování platnosti elektronických

    … více »
    Ladislav Hagara | Komentářů: 2
    včera 05:00 | Nová verze

    Rspamd (Wikipedie), tj. open source systému pro filtrování nevyžádané pošty, byl vydán v nové major verzi 4.0.0. Přehled novinek v Changelogu.

    Ladislav Hagara | Komentářů: 1
    30.3. 23:11 | Nová verze

    SolveSpace (Wikipedie), tj. multiplatformní open source parametrický 2D/3D CAD, byl vydán v nové verzi 3.2. Přehled novinek v Changelogu na GitHubu. Vyzkoušet lze novou oficiální webovou verzi.

    Ladislav Hagara | Komentářů: 10
    30.3. 18:22 | Pozvánky

    Organizátoři Dne IPv6, tradiční akce věnované tématům spojeným s tímto protokolem, vyhlásili Call for Abstracts. Na webu konference mohou zájemci přihlašovat příspěvky o délce 20 nebo 40 minut či 10minutové lighting talky a to až do 30. dubna. Tvůrci programu uvítají návrhy přednášek z akademického i komerčního sektoru, které mohou být technického i netechnického zaměření. Den IPv6 se letos uskuteční 4. června a místem konání bude i

    … více »
    VSladek | Komentářů: 12
    Které desktopové prostředí na Linuxu používáte?
     (15%)
     (7%)
     (1%)
     (12%)
     (30%)
     (3%)
     (5%)
     (1%)
     (14%)
     (23%)
    Celkem 1201 hlasů
     Komentářů: 29, poslední včera 11:17
    Rozcestník

    Zmena vzhľadu checkbox a radio inputov v HTML

    8.2.2013 21:30 | Přečteno: 2383× | Web | Výběrový blog | poslední úprava: 8.2.2013 21:30

    CSS 2.1 nedefinuje, ktoré vlastnosti CSS a akým spôsobom sa aplikujú na formulárové prvky. Prehliadač môže aplikovať CSS vlastnosti formulárovým prvkom. Odporúča sa však považovať túto funkcionalitu za experimentálnu. Budúce verzie môžu spôsob aplikovania CSS bližšie špecifikovať.
    Zdroj

    V dnešnom blogu si ukážeme spôsoby ako definovať vlastné štýly pre formulárové prvky a dôvody prečo by sme to za bežných okolností nemali robiť ;-).

    Štýl aplikovaný na formulárové elementy

    Nastavovanie štýlov formulárovým prvkom

    Definícia na stránkach W3C sa vyjadruje o možnosti definovať vlastný štýl formulárovým prvkom veľmi opatrne. Problematika je pomerne obsiahla, ja sa však v tomto blogu budem zaoberať len 2 typmi formulárových prvkov. Ak by mal niekto záujem o komplexnejší pohľad, tak celkom zaujímavý je tento blog.

    V krátkosti môžme povedať, že určiť štýl priamo checkboxom, alebo radiobuttonom je nemožné. Všetky rozumné metódy fungujú na princípe určenia štýlu nejakému inému elementu a skrytiu samotného formulárového prvku.

    Metódy založené na CSS

    Prakticky všetky metódy založené na CSS aplikujú štýl na nejaký element buď priamo zapísaný v kóde, alebo pseudo element ako je ::before, alebo ::after. Samotný formulárový prvok sa skryje (čo už s ním keď sa jeho vzhľad nedá zmeniť ;-) ).

    Na webe sa povaľuje obrovské množstvo návodov, ja však ukážem za všetky len jeden (najlepší, aký som našiel a trochu upravený mnou). Je to konkrétne návod z The CSS Ninja. HTML kód, na ktorý budemeaplikovať CSS bude vyzerať nasledovne:

    <form action="." method="get">
      <fieldset>
        <legend>Radio</legend>
        <p>
          <input type="radio" name="radio" id="radio_y" />
          <label for="radio_y">Áno</label>
        </p>
        <p>
          <input type="radio" name="radio" id="radio_n" />
          <label for="radio_n">Nie</label>
        </p>
      </fieldset>
      <fieldset>
        <legend>Checkbox</legend>
        <p>
          <input type="checkbox" name="checkbox_1" id="checkbox_y" />
          <label for="checkbox_y">Áno</label>
        </p>
        <p>
          <input type="checkbox" name="checkbox_2" id="checkbox_n" />
          <label for="checkbox_n">Nie</label>
        </p>
      </fieldset>
    </form>
    

    Samotné CSS vyzerá nasledovne:

    p input[type=checkbox], p input[type=radio]
    {
      padding: 0;
      margin: 2px 6px 0 0;
      vertical-align: middle;
    }
    

    Najskôr sa nastaví štýl pre formulárový prvok, ktorý sa použije v prípade, že prehliadač nepodporuje selektory CSS3.

    p:not(#foo) > input[type=checkbox], p:not(#foo) > input[type=radio] {
      position: absolute;
      float: left;
      left: 0;
      opacity: 0;
    }
    

    Tento blok CSS zabezpečí, že formulárový prvok sa nebude vôbec zobrazovať. Absolútna pozícia slúži na to, aby návestie nebolo posunuté o rozmery formulárového prvku.

    Hrôzostrašným selectorom p:not(#foo) dosiahneme aplikáciu pravidla len v prípade, že prehliadač podporuje CSS 3 selektory na pomerne dobrej úrovni.

    p:not(#foo) > input[type=checkbox] + label:before, p:not(#foo) > input[type=radio] + label:before
    {
      width: 16px;
      height: 18px;
      vertical-align: middle;
      content: "";
      background: url(sprity.png) 0px 0px no-repeat;
      display: inline-block;
    }
    
    p:not(#foo) > input[type=checkbox] + label:before                 { background-position: 0px    0px; }
    p:not(#foo) > input[type=checkbox] + label:hover::before          { background-position: 0px  -20px; }
    p:not(#foo) > input[type=checkbox] + label:active::before         { background-position: 0px  -40px; }
    p:not(#foo) > input[type=checkbox]:checked + label:before         { background-position: 0px  -80px; }
    p:not(#foo) > input[type=checkbox]:checked + label:hover::before  { background-position: 0px -100px; }
    p:not(#foo) > input[type=checkbox]:checked + label:active::before { background-position: 0px -120px; }
    
    p:not(#foo) > input[type=radio] + label:before                    { background-position: 0px -160px; }
    p:not(#foo) > input[type=radio] + label:hover::before             { background-position: 0px -180px; }
    p:not(#foo) > input[type=radio] + label:active::before            { background-position: 0px -200px; }
    p:not(#foo) > input[type=radio]:checked + label:before            { background-position: 0px -240px; }
    p:not(#foo) > input[type=radio]:checked + label:hover::before     { background-position: 0px -260px; }
    p:not(#foo) > input[type=radio]:checked + label:active::before    { background-position: 0px -280px; }
    

    Nakoniec sa vytvorí pseudo element, ktorý bude zobrazovať samotný ovládací prvok. Pre jednotlivé stavy elementu sa nastaví buď samostatné pozadie, alebo pozícia spritu.

    Na zariadeniach s IOS 4 a vyšším nebudú takéto prvky fungovať. Na ich oživenie sa musí nastaviť prázdna metóda onclick na formulár.

    <form action="." method="get" onclick="">
    

    Kód by mal fungovať korektne vo väčšine prehliadačov vrátane Internet Exploreru 9. V nižších verziách by sa mali zobrazovať štandardné systémové formulárové prvky.

    IE 9 IE 8

    Použitie javascriptu

    Najvyššie umiestnenie na googli má medzi skriptmi na zmenu vzhľadu formulárových prvkov tento skript. Existuje samozrejme niekoľko ďalších skriptov, ale spôsob použitia a problémy vzniknuté použitím sú prakticky rovnaké.

    Pre demonštráciu použitia tohto skriptu nám postačí ho pridať do hlavičky a formulárovým prvkom pridať triedu class="styled".

    <script src="functions.js"></script>
    

    CSS súbor je pomerne jednoduchý a myslím, že nepotrebuje žiaden komentár.

    .checkbox, .radio {
      width: 16px;
      height: 20px;
      padding: 0 5px 0 0;
      background: url(checkbox.png) no-repeat;
      display: block;
      clear: left;
      float: left;
    }
    
    .radio {
      background: url(radio.png) no-repeat;
    }
    

    Javascript sa stará o vytvorenie prvkov span, ktoré nahradia formulárové prvky. Tie sú podobne ako v prípade použitia CSS skryté. Na aplikovanie štýlu prvkov v tomto prípade nepotrebujeme ani podporu pseudo elementov (::before a ::after), ani podporu selektorov :checked a + (sused).

    Pri zmene stavu elementu priamo kliknutím na element (nie na návestie) však nedochádza ku generovaniu udalosti. Nasledujúci kód sa vyvolá len pri kliknutí na návestie.

    $('form input').change(function(e) {
      ...
    });
    

    Zároveň pri tomto stave môžu nastať problémy pri zmene stavu elementov pomocou skriptu.

    $('input').each(function() {
      $(this).prop('checked', !$(this).prop('checked'));
    });
    

    Porovnanie

    Zobrazovanie

      Chromium Firefox Opera Konqueror IE 7 IE 8 IE 9 Safari (iOS)
    CSS ✓*
    JS

    * Je potrebné trochu "ohackovať" onclick.

    Udalosti

      CSS JS  
    Generovanie zmeny Testovaný skript negeneruje udalosť change.
    Reakcia na nastavenie stavu skriptom Testovaný skript reaguje na zmenu stavu checkboxu pomocou js presne opačne (pri zaškrtnutí zobrazuje nezaškrtnutý a opačne).

    Záver

    Oba spôsoby majú svoje výhody a nevýhody. Podľa možnosti nemali by sme používať ani jednu metódu a spoľahnúť sa na to, že štandardné prvky nebudú vyzerať hrozne.

    Použitím CSS sa vyhneme problémom pri používaní skriptov riadiacich stav elementov. Zároveň sa môžme spoľahnúť na to, že všetky udalosti budú korektne vygenerované a môžme vykonať akciu pri zmene stavu. Netreba však zabúdať, že je to jednoducho len hack, ktorý sa snaží rôznymi spôsobmi obísť nekompatibilitu medzi prehliadačmi.

    Použitie javascriptu na zmenu štýlu prvkov síce funguje vo väčšom počte prehliadačov, ale má svoje muchy v podobe spolupráce s inými skriptmi.

           

    Hodnocení: 100 %

            špatnédobré        

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    Komentáře

    Vložit další komentář

    mirec avatar 8.2.2013 21:35 mirec | skóre: 32 | blog: mirecove_dristy | Poprad
    Rozbalit Rozbalit vše Re: Zmena vzhľadu checkbox a radio inputov v HTML
    Příloha:
    V prílohe sú súbory, ktoré som používal na testovanie formulárových prvkov.
    LinuxOS.sk | USE="-fotak -zbytocnosti -farebne_lcd +vydrz +odolnost +java" emerge telefon
    =^..^= AmigaPower® avatar 9.2.2013 13:36 =^..^= AmigaPower® | skóre: 30 | blog: BLB | Praha
    Rozbalit Rozbalit vše Re: Zmena vzhľadu checkbox a radio inputov v HTML
    To je hrozný ta skleróza, člověk chvíli nic nenapíše a pak do toho čumí hak husa do flašky a musí jet řádek po řádku a zase spátky, aby mu docvaklo jak to vlastně funguje... :-D
    9.2.2013 14:53 manasekp | skóre: 29 | blog: manasekp | Brno
    Rozbalit Rozbalit vše Re: Zmena vzhľadu checkbox a radio inputov v HTML
    musis na chvilu odlozit tu flasku, pak to pomalu zacne davat smysl :-D
    BIOKOMP | Cas od casu se pokousim nekoho srazit k zemi abych se tam nevalel sam.
    9.2.2013 18:23 citanus
    Rozbalit Rozbalit vše Re: Zmena vzhľadu checkbox a radio inputov v HTML
    flashku a jointa : )
    =^..^= AmigaPower® avatar 11.2.2013 07:48 =^..^= AmigaPower® | skóre: 30 | blog: BLB | Praha
    Rozbalit Rozbalit vše Re: Zmena vzhľadu checkbox a radio inputov v HTML
    ...zveš? ;-)

    Založit nové vláknoNahoru

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.