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 18:22 | Komunita

    Vývojáři webového prohlížeče Ladybird dnes oznámili, že mění způsob vývoje. S blížícím se vydáním alfa verze přestávají přijímat veřejné pull requesty. Všechny otevřené veřejné pull requesty budou uzavřeny. Tým nedokáže garantovat bezpečnost AI generovaných pull requestů.

    Ladislav Hagara | Komentářů: 2
    dnes 17:33 | Zajímavý software

    OpenLogi (GitHub) je open source náhrada aplikace Logi Options+ pro přizpůsobení myší od společnosti Logitech. Zatím běží pouze na macOS.

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

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

    Ladislav Hagara | Komentářů: 9
    včera 11:22 | Bezpečnostní upozornění

    Úřad pro ochranu osobních údajů řeší desítky stížností na jednotné měsíční hlášení zaměstnavatele, které stát spustil počátkem dubna. Systém, jenž má firmám odlehčit od desítek formulářů, nejenže výrazně zatížil jejich účetní oddělení, ale docházelo v něm i k únikům osobních dat zaměstnanců k firmám, kde nepracovali. Podle ministerstva práce a sociálních věcí stála za problémem technická chyba. „Incident se týkal několika stovek

    … více »
    Ladislav Hagara | Komentářů: 12
    včera 10:46 | Nová verze

    Byla vydána (𝕏, Bluesky) nová verze 22.0.0 open source webového aplikačního frameworku Angular (Wikipedie). Přehled novinek v příspěvku na blogu.

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

    Vim Classic byl vydán ve verzi 8.3. Drew DeVault oznámil tento fork editoru Vim (verze 8.2.0148, tj. těsně před zavedením Vim9 skriptování) v březnu letošního roku. Důvodem forku bylo, že vývojáři editorů Vim a Neovim začali při vývoji využívat LLM.

    Ladislav Hagara | Komentářů: 7
    včera 03:44 | Komunita

    Open source konference DevConf.CZ 2026 proběhne 18. a 19. června v Brně na FIT VUT. Publikován byl program a spuštěna byla registrace.

    Ladislav Hagara | Komentářů: 0
    3.6. 19:44 | Nová verze

    Společnost JetBrains uvolnila verzi 2 svého open-source velkého jazykového modelu (LLM) pro vývojáře Mellum.

    Ladislav Hagara | Komentářů: 0
    3.6. 14:44 | IT novinky

    Probíhá konference Microsoft Build 2026. Microsoft představuje své novinky: kvantový čip Majorana 2, Surface Laptop Ultra a Surface RTX Spark Dev Box s NVIDIA RTX Spark, Intelligent Terminal, Coreutils for Windows (fork Rust Coreutils), AI modely MAI, AI agenta Scout, platformu pro agent-first zařízení Project Solara, …

    Ladislav Hagara | Komentářů: 0
    3.6. 12:44 | Nová verze

    Google Chrome 149 byl prohlášen za stabilní. Nejnovější stabilní verze 149.0.7827.53 přináší řadu novinek. Podrobný přehled v poznámkách k vydání. Vylepšeny byly také nástroje pro vývojáře.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (12%)
     (8%)
     (2%)
     (15%)
     (31%)
     (4%)
     (6%)
     (3%)
     (15%)
     (26%)
    Celkem 1826 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Administrace komentářů

    Jste na stránce určené pro řešení chyb a problémů týkajících se diskusí a komentářů. Můžete zde našim administrátorům reportovat špatně zařazenou či duplicitní diskusi, vulgární či osočující příspěvek a podobně. Děkujeme vám za vaši pomoc, více očí více vidí, společně můžeme udržet vysokou kvalitu AbcLinuxu.cz.

    Příspěvek
    14.11.2013 16:05 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Opravdu pěkná PHP knihovna pro HTML formuláře

    Myslím, že píšeš minimálně o dvou, spíš o třech a věcech, jak to má vypadat a jak se s tím pracuje.

    Jak to má vypadat budu tiše ignorovat, ale například to, jak se to konvertuje, jsem v minulosti úspěšně řešil přidáním vrstvy pomocí třídy „DatovýTyp“, s definičním označením

       * 'g' = int8
       * 'h' = int16
       * 'i' = int32
       * 'I' = int64
       * 'n' = float
       * 'N' = double
       * 'm' = money
       * 's' = string
       * 'S' = binary
       * 'd' = date     interně array (Y,m,d H,i,s,miliseconds)
       * 'D' = datetime interně array (Y,m,d H,i,s,miliseconds)
       * 't' = time     interně array (Y,m,d H,i,s,miliseconds)
       * 'T' = timestamp interně timestamp 
       * 'b' = blob data  undefined .. as it 
       * 'u' = error
       * '1'-'9' = string, výčet, ('0' - bool Yes/No)
    A tento Variant reprezentoval hodnotu a uměl ji nastavit nebo vrátit ve třech formátech SQL, PHP, GUI dle konfigurace, lokalizačních informací či dle DBE a jejího nastavení. Typů bylo zbytečně moc, a datum by měl už být samozřejmě datetime, ale šlo to aplikovat na cokoliv. A ta písmenka se používala pro parametry předpřipraveného SQL dorazu.

    Co se týká validace, tak jsem měl typy a ještě někdy mám checker-y(, ale už mě to moc nebaví, tak to moc nedělám :( ):

     
      const CHECKER_notnull   = 1000001; //0 parametru
      const CHECKER_id        = 1000002; //1 parametru
      const CHECKER_length    = 1000020; //2 parametru
      const CHECKER_number    = 1000030; //2 parametru
      const CHECKER_integer   = 1000040; //2 parametru
      const CHECKER_datetime  = 1000051; //0 parametru
      const CHECKER_date      = 1000052; //0 parametru
      const CHECKER_time      = 1000053; //0 parametru
      const CHECKER_regexp    = 1000060; //2[3] parametru, 3=true znamena ze prazdny retezec je OK
      const CHECKER_emaildomain=1000090; //
      const CHECKER_aplication= 1000099; //?
    
    Které jsou definovány v DB a jsou navázány na konkrétní sloupec v DB a mají povinně implementaci v aplikační datové třídě, mohou mít a často mají implementaci v DB, buď na urovni SQL dotazu, nebo čistěji v trigger-u a mohou mít implementaci v JS.

    V aplikaci každý DB objekt (tabulka) má svoji aplikační datovou třídu, který si získá meta informace z DB a spoustu konstantních vygenerovaných informací včetně patřičných SQL dotazů má u sebe. A pokud se přistupuje aplikačně přes tuto třídu, je vše ošetřeno a zajištěno, jednoduchý UPDATE či INSERT je nejtypičtější forma vkládání dat z formuláře, takže to pokryje 98% případů.

    A pak zjednodušeně lze napsat:

    $profile->setByArray($_POST['profile']);
    $profile->Insert();
    

    První metoda (aplikace app. checker-ú) může vyhodit výjimku s informací vrácenou patřičným checkerem nebo "ResultState" instanci, která ma dané informace (a může třeba být použita jak parametr při "PrintForm" k označení špatného vstupu).
    Druhá metoda vlastní zápis do db.

    No a co se týče vzhledu formuláře, tak díky tomu, že datové třídy umí získat i přímo vázané seznamy (pro combo-a) a díky infomacích "DatovýTyp" pro každý sloupec, tak lze velmi universální fcí (přijímající jako paramtr případně i instanci ResultState) vyflusnout celý form a to i pro více tabulek současně a pokud se jednotlivé „buňky“/„divy“ o id-čkují a o clasu-jí, tak je to už jen věcí css.

    Ale měl jsem to opřené vždy o to, že celou DB včetně, app. datových tříd jsem měl vygenerovanou a overzovanou, a jakýkoliv zásah do strukturu, měl za následek nový regen, což někdy nebylo příjemné, protože automatika rozdílových SQL byla velmi slabá až žádná. Pro úpravy applikace to bylo ok - bez vlivu, samozřejmě kontrola formátu formuláře když přibyl sloupec, či doplnění nebo překlad name/title/help, ale zásah do DB modelu, pokud to nebylo jen prosté přidání tabulky, znamenalo vždy test migrace, a zabral trochu víc času než jen klik, nicméně jakékoliv změny validace či předpisu dané hodnoty bylo vždy jen v SQL a když jsem náhodu něco rozbil, tak se to hezky projevilo vyjímkou v patřičné oblasti a nemohlo dojít ke skrytým škodám. (Vedlejší pozitivní efekt byl, že meta informace o všech „objektech“ jsme měl ve stejné DB a nemusel jsem se opírat o (ne)možností daného DBE, a bylo možné ukládat přes trigery automatickou historii naprosto všeho bez jakékoliv práce (nebo s drobnou předpřípravou přes app. vrstvu) a bylo možné uložit „dokument“ k jakémukoliv objektu−>řádku rovněž bez práce, ale obojí bez integrity zajišťované přímo DBE přes FK).

    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†

    V tomto formuláři můžete formulovat svou stížnost ohledně příspěvku. Nejprve vyberte typ akce, kterou navrhujete provést s diskusí či příspěvkem. Potom do textového pole napište důvody, proč by měli admini provést vaši žádost, problém nemusí být patrný na první pohled. Odkaz na příspěvek bude přidán automaticky.

    Vaše jméno
    Váš email
    Typ požadavku
    Slovní popis
    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.