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í
×
    včera 16:44 | Nová verze

    Svobodný multiplatformní herní engine Bevy napsaný v Rustu byl vydán ve verzi 0.18. Díky 174 přispěvatelům.

    Ladislav Hagara | Komentářů: 2
    včera 15:11 | IT novinky

    Miliardy korun na digitalizaci služeb státu nestačily. Stát do ní v letech 2020 až 2024 vložil víc než 50 miliard korun, ale původní cíl se nepodařilo splnit. Od loňského února měly být služby státu plně digitalizované a občané měli mít právo komunikovat se státem digitálně. Do tohoto data se povedlo plně digitalizovat 18 procent agendových služeb státu. Dnes to uvedl Nejvyšší kontrolní úřad (NKÚ) v souhrnné zprávě o stavu digitalizace v Česku. Zpráva vychází z výsledků víc než 50 kontrol, které NKÚ v posledních pěti letech v tomto oboru uskutečnil.

    Ladislav Hagara | Komentářů: 6
    včera 13:55 | IT novinky

    Nadace Wikimedia, která je provozovatelem internetové encyklopedie Wikipedia, oznámila u příležitosti 25. výročí vzniku encyklopedie nové licenční dohody s firmami vyvíjejícími umělou inteligenci (AI). Mezi partnery encyklopedie tak nově patří Microsoft, Amazon a Meta Platforms, ale také start-up Perplexity a francouzská společnost Mistral AI. Wikimedia má podobnou dohodu od roku 2022 také se společností Google ze skupiny

    … více »
    Ladislav Hagara | Komentářů: 0
    včera 02:22 | Nová verze

    D7VK byl vydán ve verzi 1.2. Jedná se o fork DXVK implementující překlad volání Direct3D 5, 6 a 7 na Vulkan. DXVK zvládá Direct3D 8, 9, 10 a 11.

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

    Byla vydána verze 12.0.0 knihovny libvirt (Wikipedie) zastřešující různé virtualizační technologie a vytvářející jednotné rozhraní pro správu virtuálních strojů. Současně byl ve verzi 12.0.0 vydán související modul pro Python libvirt-python. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    15.1. 19:22 | Humor

    CreepyLink.com je nový zkracovač URL adres, 'díky kterému budou vaše odkazy vypadat tak podezřele, jak je to jen možné'. Například odkaz na abclinuxu.cz tento zkracovač převádí do podoby 'https://netflix.web-safe.link/logger_8oIlgs_free_money.php'. Dle prohlášení autora je CreepyLink alternativou ke zkracovači ShadyURL (repozitář na githubu), který dnes již bohužel není v provozu.

    NUKE GAZA! 🎆 | Komentářů: 3
    15.1. 12:33 | IT novinky

    Na blogu Raspberry Pi byla představena rozšiřující deska Raspberry Pi AI HAT+ 2 s akcelerátorem Hailo-10 a 8 GB RAM. Na rozdíl od předchozí Raspberry Pi AI HAT+ podporuje generativní AI. Cena desky je 130 dolarů.

    Ladislav Hagara | Komentářů: 3
    15.1. 12:11 | Komunita

    Wikipedie slaví 25. výročí svého založení. Vznikla 15. ledna 2001 jako doplňkový projekt k dnes již neexistující encyklopedii Nupedia. Doména wikipedia.org byla zaregistrována 12. ledna 2001. Zítra proběhne v Praze Večer svobodné kultury, který pořádá spolek Wikimedia ČR.

    Ladislav Hagara | Komentářů: 1
    15.1. 04:44 | Nová verze

    Po více než dvou letech od vydání předchozí verze 2.12 byla vydána nová stabilní verze 2.14 systémového zavaděče GNU GRUB (GRand Unified Bootloader, Wikipedie). Přehled novinek v souboru NEWS a v aktualizované dokumentaci.

    Ladislav Hagara | Komentářů: 2
    15.1. 02:22 | Nová verze

    Google Chrome 144 byl prohlášen za stabilní. Nejnovější stabilní verze 144.0.7559.59 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 10 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře (YouTube).

    Ladislav Hagara | Komentářů: 4
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (5%)
     (0%)
     (9%)
     (19%)
     (3%)
     (6%)
     (3%)
     (11%)
     (42%)
    Celkem 462 hlasů
     Komentářů: 12, poslední 14.1. 21:12
    Rozcestník

    React.js a JSX na localhostu

    6.3.2018 10:23 | Přečteno: 3258× | To jsem vážně jediný? | Výběrový blog | poslední úprava: 6.3.2018 10:23

    Když jsem byl loni konce léta na svatbě našich přátel, obrátil se tam na mne s dětskou důvěrou kamarádův jedenáctiletý syn – začal se zajímat o to jak se dělají webové stránky a tak chtěl vysvětlit jak to všechno funguje. S hrůzou jsem si uvědomil kolik jsem toho za ty roky zapoměl. Ovšem takové zapomínání není úplně na škodu, protože se tím zbavíte i zažitých postupů, které už jsou dávno obsolete. Každopádně mne tím přinutil abych se zase po nějakém čase podíval na věci kolem webu a javascriptu. A to jsem netušil, jak brzy se mi to bude hodit.

    V prosinci jsem konečně dostal do použitelné podoby djvutool shellový tool pro práci s DjVu soubory, když moji pozornost upoutal DjVu.js Podle všeho v rámci tohoto repozitáře oprášil Nikolaj Suchanov svůj původní javascriptový kód pro čtení obrazové informace DjVu souborů z r. 2014 a přepsal ho do ECMA6.

    Tím ovšem defakto vyřešil můj základní problém, který stál v mé cestě za dlouhodobým cílem – mít k dispozici multiplatformní nástroj pro práci s DjVu soubory. Javascriptový editor pro úpravy textové vrstvy DjVu souborů už totiž existuje – WebDjVuTextEd. Má však jednu zásadní vadu – je závislý na nástrojích DjVuLibre, stejně jako ten můj shellový skript.

    Skloubením těchto dvou aplikací však lze vytvořit aplikaci zcela multiplatformní, použitelnou bez ohledu na OS. Pěkná myšlenka, není-liž pravda? Ti co se o věc zajímají vědí, že ani komerční nástroje pro práci s DjVu soubory (které už dávno nejsou k dispozici) nikdy neměly tak komfortní možnosti úpravy textové vrstvy. O metadatech ani nemluvě.

    Vyhrabal jsem tedy z hloubi duše trosky a pustil se do studia kódu DjVu.js To pro mne znamenalo především se dokopat k podrobnějšímu seznámení s využitím javascriptových konzolí a debuggerů, co nabízejí moderní weboví prohlížeče. Tyjo, mít takový luxus na zkoumání kódu v oněch dřevních dobách, to by byla jiná káva. No nic.

    Především jsem zjistil, že autor DjVu.js začal přepracovávat svůj původní, víceméně nezávislý kód způsobem, který se mi moc nelíbí. Chápu jeho pohnutky, ale nevidím nejmenší důvod, proč bych měl kvůli dvou tří víceméně statických knihoven stahovat dalších 250MB dat. Následující text tedy nebude o mém zápolení s javascriptem, ale o tom jak se tomu vyhnout.

    Původní kód DjVu.js pracoval s knihovnou jQuery (v2.1.1). Současná verze používala verzi novější, ale autor se rozhodl místo ní použít React.js

    Nic proti, React.js je rozhodně správná volba, ale přiznám se, že jsem tím nadšen nebyl, protože tím pádem přestaly fungovat starší části jeho kódu, které řešily věci, které jsem potřeboval. A s postupem spojeným s instalací npm jsem k rozumnému výsledku nedošel. Problém totiž spočíval v tom, že svůj DjVu prohlížeč dělá primárně k webovému nasazení, kdežto mým záměrem je aby aplikace fungovala i bez toho že by byla závislá na webovém připojení.

    Vrátil jsem se tedy nejprve ke starší verzi jeho kódu, kde byla k dispozici knihovna jquery-3.2.1.min.js abych mohl zjistit na čem kód DjVu.js havaruje. Což se mi podařilo. A když už jsem byl v tom, dopsal jsem si i věci, které mu chybí - především jde o třídy pro zpracování skryté textové vrstvy a metadat.

    Pak přišel na řadu druhý krok. Klíčovou výhodou pro nasazení React.js je skutečnost, že umožňuje dynamicky přegenerovat dílčí nody DOM modelu stránky přímo javascriptem, aniž by při tom bylo nutné pokaždé znovu načítat celý DOM objekt. U původní stránky to bylo řešeno tak, že se měnilo javascriptem nastavení atributu viditelnosti u div elementů.

    Ovšem jak to udělat, aniž by bylo nutné instalovat to zpropadené Node.js?

    Odpověď na mou otázku mi dal blogpost, který před dvěma lety napsal Shing Lyu. Až dodatečně jsem pak zjistil, že ani ne před měsícem publikoval jeho aktualizovanou verzi. Nechci tady uvádět tupý překlad jeho blogpostu, takže se omezím pouze na detail.

    Shing Lyu ve svém blogpostu uvádí, jak přilinkovat potřebné knihovny tak, aby nebylo nutné používat npm. Já osobně jsem si raději potřebné knihovny stáhnul rovnou do prepozitáře, abych nebyl závislý na připojení, když chci na kódu pracovat offline. Navíc zkušenost s aplikací WebDjVuTextEd mě poučila, že je lepší mít všechny potřebné kódy pohromadě, než spoléhat na to, že budou ke stažení z původní lokace navždy.

    Stáhnul jsem si tedy jak verze development, se kterými se lépe pracuje při trasování kódu, tak verze komprimované – pro budoucí finální použití.

    <!DOCTYPE html>
    <html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
        <title>Test</title>
        <script type="text/javascript" src="app/react.development.js"></script>
        <script type="text/javascript" src="app/react-dom.development.js"></script>
        <script type="text/javascript" src="app/babel.js"></script>
    </head>
    
    <body>
    <div id='root'>
    <script type="text/babel">
    function tick() {
      const element = (
        <div>
          <h1>Hello, world!</h1>
          <h2>It is {new Date().toLocaleTimeString()}.</h2>
        </div>
      );
      ReactDOM.render(element, document.getElementById('root'));
    }
    
    setInterval(tick, 1000);
    </script>
    </div>
    </body>
    </html>
    
    Upozorňuji na zvýrazněnou část kódu - bez ní JSX syntaxe (kterou zpracovává babel.js) fungovat nebude.        

    Hodnocení: 100 %

            špatnédobré        

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

    Komentáře

    Vložit další komentář

    6.3.2018 21:34 Aleš
    Rozbalit Rozbalit vše Re: React.js a JSX na localhostu
    Ahoj, Posílám ti lepší variantu. Určitě bych stále nezahazoval celou React inicializaci, ale použil state v rámci React komponenty.

    Příklad zde:

    https://codepen.io/anon/pen/rJXMBb?editors=1010
    6.3.2018 22:04 Want
    Rozbalit Rozbalit vše Re: React.js a JSX na localhostu
    To byl jen narychlo plácnutý příklad. Ke konkrétnímu řešení se dostanu až bude chvíli čas. Navíc budu muset v prvé řadě přepsat část původního kódu pro ty DjVu dokumenty. Autor kupř. vůbec nepočítal s náhledy. Navíc je zbytečné zpracovávat celý dokument najednou. A některé funkcionality v těch třídách chybí zcela. Ale určitě díky za každý zajímavý tip.
    =^..^= AmigaPower® avatar 7.3.2018 11:26 =^..^= AmigaPower® | skóre: 30 | blog: BLB | Praha
    Rozbalit Rozbalit vše Re: React.js a JSX na localhostu
    Jo jo, člověk zapomíná kurevsky rychle, já chtěl nedávno něco předělat na webu a zkončil jsem u<head> :-D Když jsem si otevřel jakpsatweb.cz, tak mi to sice začlo všechno zas docházet, ale stejně jsem se musel koukat na každej atribut jak se píše, protože to dělám v KWrite a ten validitu nemá jak zkontrolovat :-D
    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.