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 04:22 | Pozvánky

    Letos se uskuteční již 11. ročník soutěže v programování Kasiopea. Tato soutěž, (primárně) pro středoškoláky, nabízí skvělou příležitost procvičit logické myšlení a dozvědět se něco nového ze světa algoritmů – a to nejen pro zkušené programátory, ale i pro úplné začátečníky. Domácí kolo proběhne online od 22. 11. do 7. 12. 2025 a skládá se z 9 zajímavých úloh různé obtížnosti. Na výběru programovacího jazyka přitom nezáleží – úlohy jsou

    … více »
    SoutezKasiopea | Komentářů: 0
    dnes 04:11 | Nová verze

    Byla vydána nová verze 2.52.0 distribuovaného systému správy verzí Git. Přispělo 94 vývojářů, z toho 33 nových. Přehled novinek v příspěvku na blogu GitHubu a v poznámkách k vydání.

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

    VKD3D-Proton byl vydán ve verzi 3.0. Jedná se fork knihovny vkd3d z projektu Wine pro Proton. Knihovna slouží pro překlad volání Direct3D 12 na Vulkan. V přehledu novinek je vypíchnuta podpora AMD FSR 4 (AMD FidelityFX Super Resolution 4).

    Ladislav Hagara | Komentářů: 0
    včera 03:11 | Nová verze

    Poštovní klient Thunderbird byl vydán v nové verzi 145.0. Podporuje DNS přes HTTPS nebo Microsoft Exchange skrze Exchange Web Services. Ukončena byla podpora 32bitového Thunderbirdu pro Linux.

    Ladislav Hagara | Komentářů: 1
    včera 02:33 | IT novinky

    U příležitosti státního svátku 17. listopadu probíhá na Steamu i GOG.com již šestý ročník Czech & Slovak Games Week aneb týdenní oslava a také slevová akce českých a slovenských počítačových her.

    Ladislav Hagara | Komentářů: 0
    16.11. 19:33 | Nová verze

    Byla vydána nová verze 9.19 z Debianu vycházející linuxové distribuce DietPi pro (nejenom) jednodeskové počítače. Přehled novinek v poznámkách k vydání. Vypíchnout lze například nový balíček BirdNET-Go, tj. AI řešení pro nepřetržité monitorování a identifikaci ptáků.

    Ladislav Hagara | Komentářů: 0
    16.11. 02:22 | Nová verze

    Byla vydána nová verze 3.38 frameworku Flutter (Wikipedie) pro vývoj mobilních, webových i desktopových aplikací a nová verze 3.10 souvisejícího programovacího jazyka Dart (Wikipedie).

    Ladislav Hagara | Komentářů: 0
    16.11. 01:33 | Nová verze

    Organizace Apache Software Foundation (ASF) vydala verzi 28 integrovaného vývojového prostředí a vývojové platformy napsané v Javě NetBeans (Wikipedie). Přehled novinek na GitHubu. Instalovat lze také ze Snapcraftu a Flathubu.

    Ladislav Hagara | Komentářů: 0
    15.11. 16:11 | Nová verze

    Byl vydán Debian 13.2, tj. druhá opravná verze Debianu 13 s kódovým názvem Trixie. Řešeny jsou především bezpečnostní problémy, ale také několik vážných chyb. Instalační média Debianu 13 lze samozřejmě nadále k instalaci používat. Po instalaci stačí systém aktualizovat.

    Ladislav Hagara | Komentářů: 0
    15.11. 12:11 | IT novinky

    Google představil platformu Code Wiki pro rychlejší porozumění existujícímu kódu. Code Wiki pomocí AI Gemini udržuje průběžně aktualizovanou strukturovanou wiki pro softwarové repozitáře. Zatím jenom pro veřejné. V plánu je rozšíření Gemini CLI také pro soukromé a interní repozitáře.

    Ladislav Hagara | Komentářů: 5
    Jaké řešení používáte k vývoji / práci?
     (35%)
     (46%)
     (19%)
     (18%)
     (23%)
     (15%)
     (23%)
     (16%)
     (16%)
    Celkem 361 hlasů
     Komentářů: 16, poslední 12.11. 18:21
    Rozcestník

    Jak uložit a načíst obsah formuláře na straně klienta?

    8.12.2010 11:00 | Přečteno: 1269× | Programování | poslední úprava: 8.12.2010 15:41

    Dnes jsem řešil zdánlivě nezajímavou věc. Uchování obsahu formuláře, který je na webu stále vidět a jeho obsah by se neměl měnit, dokud nedojde ze strany uživatele ke změně a znovuodeslání. Zároveň je nemožné provést uložení například do SESSION, či jinak, a naplnění formuláře ze strany serveru - např. PHP - při vykreslování.

    Výše uvedená fakta mne vedla k jednoznačné volbě - COOKIES. Pravda, pokud je bude mít klient zakázané, řešení je k ničemu. Bude tedy využito JS, jQuery a několik rozšíření. První rozšířením bude skript pro čtení a nastavování hodnot ve formuláři (v ukázce uloženo do samostatného souboru - jquery.formvalues.js), dále budeme potřebovat jquery.json.js a jquery.cookie.js.

    A nyní je již vše jednoduché.

    <script src="http://code.jquery.com/jquery-1.4.4.js"></script>
    <script src="jquery.cookie.js"></script>
    <script src="jquery.json-2.2.min.js"></script>
    <script src="jquery.formvalues.js"></script>
    <title>Form</title>
    <script>
    /* <![CDATA[ */
    function storeForm() {
    	var date = new Date();
    	date.setTime(date.getTime() + (24 * 60 * 60 * 1000)); // 24 hours
    	$.cookie('cookie-form', $.compactJSON($('#form').values()), { path: '/', expires: date });
    }
    
    
    $(document).ready(function() {
    	if($.cookie('cookie-form') != null) {
    		$('#form').values($.secureEvalJSON($.cookie('cookie-form')));
    	}
    	
    });
    /* ]]> */
    </script>
    ...
    <form id="form" method="post" action="...">
    	<input type="text" name="firstname" value="" /><br />
    	<input type="text" name="lastname" value="" /><br />	
    	<input type="submit" value="Odeslat" onclick="storeForm()" />
    </form>
    

    Není to nic extra, ale třeba to někomu pomůže.

    Inspirováno komentáři - v případě využití local storage je řešení následující. Navíc bude potřeba jquery.jstorage.js a úprava:

    <script src="http://code.jquery.com/jquery-1.4.4.js"></script>
    <script src="jquery.cookie.js"></script>
    <script src="jquery.json-2.2.min.js"></script>
    <script src="jquery.formvalues.js"></script>
    <script src="jquery.jstorage.js"></script>
    <title>Form</title>
    <script>
    /* <![CDATA[ */
    function storeForm() {
    	if($.jStorage.storageAvailable()) {
    		$.jStorage.set('cookie-form', $('#form').values());
    	} else {
    		var date = new Date();
    		date.setTime(date.getTime() + (24 * 60 * 60 * 1000)); // 24 hours
    		$.cookie('cookie-form', $.compactJSON($('#form').values()), { path: '/', expires: date });
    	}
    }
    
    
    $(document).ready(function() {
    	if($.jStorage.storageAvailable()) {
    		if($.jStorage.get('cookie-form', null) != null) {
    			$('#form').values($.jStorage.get('cookie-form'));
    		}
    	} else {
    		if($.cookie('cookie-form') != null) {
    			$('#form').values($.secureEvalJSON($.cookie('cookie-form')));
    		}
    	}	
    });
    /* ]]> */
    </script>
    ...
    <form id="form" method="post" action="...">
    	<input type="text" name="firstname" value="" /><br />
    	<input type="text" name="lastname" value="" /><br />	
    	<input type="submit" value="Odeslat" onclick="storeForm()" />
    </form>
    

    Díky za nápad na zlepšení. O local storage jsem věděl, ale omezení COOKIES mne nenapadlo. Ještě jednou díky.

           

    Hodnocení: 67 %

            špatnédobré        

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

    Komentáře

    Vložit další komentář

    8.12.2010 11:59 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Jak uložit a načíst obsah formuláře na straně klienta?
    Pozor na to, že množství cookies a jejich celková velikost je omezené, větší formulář by se tam nemusel vejít. Moderní prohlížeče mají různá rozšíření umožňující ukládat uživatelská data (některá i pro offline prohlížení), která mají větší kapacitu.
    8.12.2010 14:13 chrono
    Rozbalit Rozbalit vše Re: Jak uložit a načíst obsah formuláře na straně klienta?
    Presne tak. Na toto je lepšie použiť localStorage a cookies použiť len keď prehliadač localStorage nepodporuje, alebo je to zakázané. Navyše sa tie údaje nebudú, pri localStorage, zbytočne posielať serveru.
    Toman avatar 8.12.2010 15:44 Toman | skóre: 29 | blog: Tomanův blog | Kostelec nad Orlicí
    Rozbalit Rozbalit vše Re: Jak uložit a načíst obsah formuláře na straně klienta?
    Zápisek jsem doplnil o možnost local storage. Děkuji za věcné připomínky.
    8.12.2010 12:54 Senior Database Programmer
    Rozbalit Rozbalit vše Re: Jak uložit a načíst obsah formuláře na straně klienta?
    To som nepochopil. Píšeš, že cookies nemôžeš použiť pretože ich user môže mať vypnuté ale v tom JavaScripte to predsa ukladáš do cookies ?! Alebo tie cookies z tej JS knižnice JQuery sú iné ako normálne cookies browsera? Nevzťahuje sa na ne zákaz ak ich má user v browsery vypnuté? Sorry, za blbé otázky, niesom web developer.
    pavlix avatar 8.12.2010 13:24 pavlix | skóre: 54 | blog: pavlix
    Rozbalit Rozbalit vše Re: Jak uložit a načíst obsah formuláře na straně klienta?
    Psal, že nemůže použít SESSIONS, ne COOKIES.
    Já už tu vlastně ani nejsem. Abclinuxu umřelo.
    9.12.2010 20:16 zulu
    Rozbalit Rozbalit vše Re: Jak uložit a načíst obsah formuláře na straně klienta?

    Takže formulář, který je stále vidět.
    A jaký smysl teda má držení hodnot jinde než v něm?

    A nemůžeš ho naplnit na straně serveru.
    Pokud ho nemůžeš plnit, tak ho nemůžeš ani zpracovávat, tak k čemu tam je?

    Bedňa avatar 11.12.2010 14:06 Bedňa | skóre: 34 | blog: Žumpa | Horňany
    Rozbalit Rozbalit vše Re: Jak uložit a načíst obsah formuláře na straně klienta?
    Nechápem zmysel, prečo tie dáta nemôžeš poslať cez POST?
    KERNEL ULTRAS video channel >>>

    Založit nové vláknoNahoru

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