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 02:33 | Nová verze

    Po více než roce vývoje od vydání verze 5.40 byla vydána nová stabilní verze 5.42 programovacího jazyka Perl (Wikipedie). Do vývoje se zapojilo 64 vývojářů. Změněno bylo přibližně 280 tisíc řádků v 1 500 souborech. Přehled novinek a změn v podrobném seznamu.

    Ladislav Hagara | Komentářů: 2
    dnes 01:33 | Nová verze

    Byla vydána nová stabilní verze 7.5 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 138. Přehled novinek i s náhledy v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    včera 16:33 | Zajímavý software

    Sniffnet je multiplatformní aplikace pro sledování internetového provozu. Ke stažení pro Windows, macOS i Linux. Jedná se o open source software. Zdrojové kódy v programovacím jazyce Rust jsou k dispozici na GitHubu. Vývoj je finančně podporován NLnet Foundation.

    Ladislav Hagara | Komentářů: 0
    včera 12:33 | Nová verze

    Byl vydán Debian Installer Trixie RC 2, tj. druhá RC verze instalátoru Debianu 13 s kódovým názvem Trixie.

    Ladislav Hagara | Komentářů: 0
    včera 03:33 | Komunita

    Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za červen (YouTube).

    Ladislav Hagara | Komentářů: 0
    včera 02:33 | Nová verze

    Libreboot (Wikipedie) – svobodný firmware nahrazující proprietární BIOSy, distribuce Corebootu s pravidly pro proprietární bloby – byl vydán ve verzi 25.06 "Luminous Lemon". Přidána byla podpora desek Acer Q45T-AM a Dell Precision T1700 SFF a MT. Současně byl ve verzi 25.06 "Onerous Olive" vydán také Canoeboot, tj. fork Librebootu s ještě přísnějšími pravidly.

    Ladislav Hagara | Komentářů: 0
    včera 01:33 | Komunita

    Licence GNU GPLv3 o víkendu oslavila 18 let. Oficiálně vyšla 29. června 2007. Při té příležitosti Richard E. Fontana a Bradley M. Kuhn restartovali, oživili a znovu spustili projekt Copyleft-Next s cílem prodiskutovat a navrhnout novou licenci.

    Ladislav Hagara | Komentářů: 0
    2.7. 16:55 | Nová verze

    Svobodný nemocniční informační systém GNU Health Hospital Information System (HIS) (Wikipedie) byl vydán ve verzi 5.0 (Mastodon).

    Ladislav Hagara | Komentářů: 0
    2.7. 16:22 | Komunita

    Open source mapová a navigační aplikace OsmAnd (OpenStreetMap Automated Navigation Directions, Wikipedie, GitHub) oslavila 15 let.

    Ladislav Hagara | Komentářů: 1
    2.7. 11:55 | Zajímavý software

    Vývojář Spytihněv, autor počítačové hry Hrot (Wikipedie, ProtonDB), pracuje na nové hře Brno Transit. Jedná se o příběhový psychologický horor o strojvedoucím v zácviku, uvězněném v nejzatuchlejším metru východně od všeho, na čem záleží. Vydání je plánováno na čtvrté čtvrtletí letošního roku.

    Ladislav Hagara | Komentářů: 41
    Jaký je váš oblíbený skriptovací jazyk?
     (59%)
     (28%)
     (7%)
     (2%)
     (0%)
     (1%)
     (3%)
    Celkem 352 hlasů
     Komentářů: 16, poslední 8.6. 21:05
    Rozcestník

    Ikonka pro pojmy ve slovníku a podpora CSS3

    25.10.2005 11:27 | Přečteno: 1438× | Abc | poslední úprava: 25.10.2005 21:37

    Konečně jsem se dostal k tomu, abych nakreslil malinkou ikonku, která by označovala odkazy na pojmy ve slovníku. Doufám, že je rozpoznatelné, co obrázek () značí (je to knížka, přece..., neříkejte, že to není poznat...). Řekl bych, že i s černým pozadím vypadá obrázek obstojně, takže jsem nedělal dvě verze zvlášť pro světlý a tmavý styl. Kdyby měl někdo nutkání obrázek vylepšit nebo vyrobit úplně nový a lepší, nebudu se vůbec zlobit.

    CSS definice:

    Vložení ikonky za každý odkaz na pojem ve slovníku jsem řešil atributovým selektorem ([href^="/slovnik/"]) a pseudoelementem :after. Vzhledem k tomu, že MS IE ani Opera (včetně vývojové verze Opera 9.0) první definici nepodporují (jde o CSS 3), uvidíte ikonky pouze v Konqueroru a Firefoxu/Mozille. Safari nemám možnost otestovat, ale předpokládám, že by to už umět mohl. Současný kód vypadá takto (doplňte do alternativních CSS):

    .st a[href^="/slovnik/"]:after {
      content:   url('/images/site2/slovnik.png');
      margin:    0 0.1em 0 0.2em;
    }

    UPDATE:

    Doplnil jsem následující definici, aby bylo možné zobrazování ikonek vypnout (jak v rámci většího elementu, tak u jednotlivých odkazů). Uvědomil jsem si, že je něco takového potřeba, když jsem se podíval na seznam všech termínů na adrese www.abclinuxu.cz/slovnik - bylo tam krapet přeikonkováno.

    .st .bez-slovniku a:after, .st a.bez-slovniku:after {
      content:   "";
      margin:    0;
    }

    (Tj. všechny odkazy, které ukazují na relativní URL začínající na /slovnik/, budou mít za sebou zobrazenou ikonku. Viz třeba článek Rozhovor: Petr "Pasky" Baudiš - ten je se slovníkem štědře prolinkovaný.)

    Nelíbí se mi na tom jen to, že při použití :after/:before nelze určit vertikální zarovnání/polohu (pokud se pletu, opravte mě, prosím). Ikonka tedy není zarovnaná s vrchním okrajem písma, což jsem původně chtěl. Teď vypadá prostě jako podivné písmenko umístěné v jedné rovině s ostatním textem. Vertikální zarovnání bych mohl vyřešit, kdybych pro zobrazení ikonky použil background-image místo :after, ale takový zápis se mi líbí daleko méně. Nehledě na to, že bych pak nemohl specifikovat požadovaný odstup ikonky od textu odkazu. Definice by vypadala takto:

    .st a[href^="/slovnik/"] {
      background-image:    url('/images/site2/slovnik.png');
      background-position: top right;
      background-repeat:   no-repeat;
      padding-right:       12px;
    }

    Poznámka k MS IE a Opeře:

    Nejsem samozřejmě nadšený z toho, že naše CSS nefunguje se stejným výsledkem ve všech běžně používaných prohlížečích. Ale snažím se držet zásady "funkční všude, 100procentní v těch dobrých". Věřím, že Opera v dohledné době podporu implementuje, nad IE lámu hůl. Možná bychom mohli někam do rohu stránek šoupnout to logo Too Cool for IE :-).

           

    Hodnocení: -

    zatím nehodnoceno
            špatnédobré        

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

    Komentáře

    Vložit další komentář

    25.10.2005 11:42 Michal Vyskočil | skóre: 60 | blog: miblog | Praha
    Rozbalit Rozbalit vše Re: Ikonka pro pojmy ve slovníku a podpora CSS3
    Ikonky too cool for IE jsou divné, rozhodně se k ábíčku vzhledově nehodí.
    When your hammer is C++, everything begins to look like a thumb.
    25.10.2005 11:49 Robert Krátký | skóre: 94 | blog: Robertův bloček
    Rozbalit Rozbalit vše Re: Ikonka pro pojmy ve slovníku a podpora CSS3
    Já to taky nemyslel vážně :-). I kdyby se hodily, stejně bychom žádnou pravděpodobně na stránky nedali...
    25.10.2005 13:28 Michal Vyskočil | skóre: 60 | blog: miblog | Praha
    Rozbalit Rozbalit vše Re: Ikonka pro pojmy ve slovníku a podpora CSS3
    Ale nápad to není špatný. Ideální by bylo si udělat v CSS vlastní textové tlačítko. A všechny problémy s IE bys měl vyřešeny (sorry, naše stránka je too cool for IE :-D).
    When your hammer is C++, everything begins to look like a thumb.
    25.10.2005 17:23 6xx
    Rozbalit Rozbalit vše Re: Ikonka pro pojmy ve slovníku a podpora CSS3
    myslim, ze tady nikdo IE nepuziva, maximalne pri vyvoji designu stranek aby vydel, jak nektere prohlizece (==prohlizec) dokazou validni styl zprasit
    25.10.2005 13:30 Oswald
    Rozbalit Rozbalit vše Re: Ikonka pro pojmy ve slovníku a podpora CSS3
    Nehledě na to, že bych pak nemohl specifikovat požadovaný odstup ikonky od textu, který za ní následuje.

    Mohl :)

    .st a[href^="/slovnik/"] {
    margin-right: 1em; 
    }
    
    25.10.2005 13:42 Robert Krátký | skóre: 94 | blog: Robertův bloček
    Rozbalit Rozbalit vše Re: Ikonka pro pojmy ve slovníku a podpora CSS3
    Sorry, už jsem z toho zblblý, takže jsem se přepsal. Chtěl jsem říct "od textu odkazu". Tuhle vzdálenost je totiž nutné určit pomocí px (je nutné definovat minimálně tolik, kolik je šířka obrázku). Takže když nastavím hodnotu pomocí px, nebude se dynamicky měnit podle velikosti písma v prohlížeči. A kdybych ten padding nastavil pomocí em, nemůžu zase zaručit, že to bude ta správná šířka.

    Opravím to v textu.
    Josef Kufner avatar 25.10.2005 14:38 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Ikonka pro pojmy ve slovníku a podpora CSS3
    vlastnost vertical-align tam nefunguje?
    Hello world ! Segmentation fault (core dumped)
    25.10.2005 17:20 Robert Krátký | skóre: 94 | blog: Robertův bloček
    Rozbalit Rozbalit vše Re: Ikonka pro pojmy ve slovníku a podpora CSS3
    Pokud vím, tak ne.
    25.10.2005 14:21 Jiří (BoodOk) Kadeřávek | skóre: 19 | blog: BoodOk | Brno
    Rozbalit Rozbalit vše Re: Ikonka pro pojmy ve slovníku a podpora CSS3
    Safari jsem ověřil. Funguje jak má.
    Věda má v sobě určitou zpupnost, že čím dokonalejší techniku vyvineme, čím více se dozvíme, tím lepší budou naše životy.
    25.10.2005 21:01 Robert Krátký | skóre: 94 | blog: Robertův bloček
    Rozbalit Rozbalit vše Re: Ikonka pro pojmy ve slovníku a podpora CSS3
    Zjišťuji zajímavé věci... např. Opera (9) podporuje selektor [atribut*=hodnota], který je ovšem součástí CSS3. To by mě zajímalo, proč nepodporuje ty ostatní. Jenže kdybych ho použil, matchnul by se každý odkaz, který má v URL /slovnik/, což nechci riskovat.

    Naopak CSS2 selektor [atribut|=hodnota], který by měl matchnout všechny elementy, jejichž atribut se buď rovná nebo začíná na hodnota, má v prohlížečích FF a Konq. podporu podivnou (Opera nic): když hodnota začíná znakem /, selektor nefunguje. Stačí však, abych zadal hod/nota a už se řetězec matchne. Nevíte někdo, proč to tak je?
    Luk avatar 25.10.2005 21:25 Luk | skóre: 47 | blog: Kacířské myšlenky | Kutná Hora
    Rozbalit Rozbalit vše Re: Ikonka pro pojmy ve slovníku a podpora CSS3
    To by mě zajímalo, proč nepodporuje ty ostatní.
    A nebude to tím, že je to teprve technical preview? Také porůznu používám O9 (tak půl napůl s osmou) a narážím i na jiné problémy. Takže třeba to ve finální verzi bude :-)
    Šifrování je absolutní nutnost a pomáhá chránit před nekalými živly
    25.10.2005 21:39 Robert Krátký | skóre: 94 | blog: Robertův bloček
    Rozbalit Rozbalit vše Re: Ikonka pro pojmy ve slovníku a podpora CSS3
    Asi máš pravdu. Mě na tom jen mate skutečnost, že jeden selektor implementovali a druhý ne... přitom jsou ze stejné "sady".
    26.10.2005 09:17 Robert Krátký | skóre: 94 | blog: Robertův bloček
    Rozbalit Rozbalit vše Negace
    Narazil jsem na další věc, které nerozumím... Zatím řeším případy, ve kterých nechci, aby se ikonka zobrazovala, pomocí separátní definice (kterou jsem do článku doplnil o něco později):
    .st .bez-slovniku a:after, .st a.bez-slovniku:after {
      content:   "";
      margin:    0;
    }
    Ale elegantnější by bylo to zvládnout všechno v rámci jediné definice. Tj. říci, že ikonka se má zobrazit u všech odkazů, ovšem pouze za předpokladu, že se tento odkaz nachází v elementu, který nemá definovanou třídu bez-slovniku. Mělo by to jít pomocí negační pseudo-třídy, ale nedaří se mi to. Můj zápis by vypadal takto:
    *:not([class="bez-slovniku"]) a[href^="/slovnik/"]:after {
      content:   url('slovnik.png');
      margin:    0 0.1em 0 0.2em;
    }
    Zápis :not([class="bez-slovniku"]) je ekvivalentní k :not(.bez-slovniku) -- dávám ho sem jen pro názornost.

    Co by to mělo dělat? Vložit content (ikonku) za každý element a, který má atribut href začínající na /slovník/, a zároveň je jeho rodičem jakýkoliv (*) element, který _nemá_ (:not) definovanou třídu bez-slovníku.

    Bohužel to nefunguje.

    Princip by však měl být správný, protože např. následující definice už funguje:
    p:not(.bez-slovniku) a[href^="/slovnik/"]:after {
      content:   url('slovnik.png');
      margin:    0 0.1em 0 0.2em;
    }
    Zápisy se liší jenom tím zvýrazněným p, ničím jiným. A tentokrát skutečně dojde k tomu, že je ikonka vložena za každý odkaz, který se nachází v rámci každého elementu p, který _nemá_ třídu bez-slovníku.

    Tak čím to je? Proč nefunguje zápis pomocí wildcards, když by měl. Např. následující zápis se chová podle očekávání:
    *:not(.bez-slovniku):after {
      content:   url('slovnik.png');
    }
    Vloží totiž ikonku za úplně každý element, který _nemá_ třídu bez-slovníku. Jakmile ale doplním child element (např. a) a zároveň použiji * a ne konkrétní název elementu (jako v případě p), zápis nefunguje.
    26.10.2005 15:29 Michal Čihař | skóre: 61 | blog: Bláboly | Praha
    Rozbalit Rozbalit vše Re: Ikonka pro pojmy ve slovníku a podpora CSS3
    Ikonka se zobrazuje třeba u odkazu na editaci pojmu ve slovníku, jeho tisk nebo zapnutí sledování, tam by asi být nemusela :-).
    26.10.2005 15:38 Robert Krátký | skóre: 94 | blog: Robertův bloček
    Rozbalit Rozbalit vše Re: Ikonka pro pojmy ve slovníku a podpora CSS3
    Dík. Opraveno.

    Založit nové vláknoNahoru

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