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 05:33 | IT novinky

    Samsung představil headset Galaxy XR se 4K Micro-OLED displeji, procesorem Snapdragon XR2+ Gen 2, 16 GB RAM, 256 GB úložištěm, operačním systémem Android XR a Gemini AI.

    Ladislav Hagara | Komentářů: 1
    dnes 05:22 | Nová verze

    Před konferencí Next.js Conf 2025 bylo oznámeno vydání nové verze 16 open source frameworku Next.js (Wikipedie) pro psaní webových aplikací v Reactu. Přehled novinek v příspěvku na blogu.

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

    Sovereign Tech Fund oznámil finanční podporu následujících open source projektů: Scala, SDCC, Let's Encrypt, Servo, chatmail, Drupal, Fedify, openprinting, PHP, Apache Arrow, OpenSSL, R Project, Open Web Docs, conda, systemd a phpseclib.

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

    Bylo vydáno OpenBSD 7.8. S předběžnou podporou Raspberry Pi 5. Opět bez písničky.

    Ladislav Hagara | Komentářů: 0
    včera 05:44 | Nová verze Ladislav Hagara | Komentářů: 2
    včera 05:22 | Bezpečnostní upozornění

    Byly publikovány informace o kritické zranitelnosti v knihovně pro Rust async-tar a jejích forcích tokio-tar, krata-tokio-tar a astral-tokio-tar. Jedná se o zranitelnost CVE-2025-62518 s CVSS 8.1. Nálezci je pojmenovali TARmageddon.

    Ladislav Hagara | Komentářů: 3
    21.10. 23:15 | Nová verze

    AlmaLinux přinese s verzí 10.1 podporu btrfs. XFS bude stále jako výchozí filesystém, ale instalátor nabídne i btrfs. Více informací naleznete v oficiálním oznámení.

    Max | Komentářů: 3
    21.10. 22:33 | IT novinky

    Společnost OpenAI představila svůj vlastní webový prohlížeč ChatGPT Atlas. Zatím je k dispozici pouze na macOS.

    Ladislav Hagara | Komentářů: 0
    21.10. 14:33 | Nová verze

    Desktopové prostředí KDE Plasma bylo vydáno ve verzi 6.5 (Mastodon). Přehled novinek i s videi a se snímky obrazovek v oficiálním oznámení. Podrobný přehled v seznamu změn.

    Ladislav Hagara | Komentářů: 3
    21.10. 13:55 | IT novinky

    Rodina jednodeskových počítačů Orange Pi se rozrostla (𝕏) o Orange Pi 6 Plus.

    Ladislav Hagara | Komentářů: 13
    Jaké řešení používáte k vývoji / práci?
     (36%)
     (48%)
     (20%)
     (20%)
     (22%)
     (18%)
     (21%)
     (18%)
     (18%)
    Celkem 257 hlasů
     Komentářů: 14, poslední 14.10. 09:04
    Rozcestník

    Dotaz: Javascript neaktualizuje element

    15.9.2022 01:10 RadekXxX | skóre: 10
    Javascript neaktualizuje element
    Přečteno: 486×

    Ahoj, kod jsem maximalne zjednodusil, ma delat to, ze mam DIV rules_1 a rules_2, ma se nacist INI soubor, ktery obsahuje X parametru pro rules_1 a X parametru pro rules_2, ty parametry ma dynamicky vlozit do DIV rules_1 a rules_2. Priklad by mel do rules_1 vytvorit 1 pravidlo a k hodnote input pridat 'ok'. Do rules_2 by mel vytvorit 2 pravilda a pridat do input 'ok', ale prvni input se nezmeni, kdyz se divam do konzole, tak vypisuje, ze input se zmenil, ale v prohlizeci neni input aktualizovan.

    <div id="rules_1"></div>

    <div id="rules_2"></div>

     

    <script>

    var initVal=0;

     

    function addRule (idx){

    initVal++;

    let dest = document.getElementById ('rules_' + idx);

    dest.innerHTML += '<input type=text value="' + initVal + '" class="Rule_' + idx + '_DTValue"><br>';

    }

     

    function load (){

    let ini = {};

    ini['Rule_1'] = {};

    ini['Rule_1']['OutputIdx'] = 1;

     

    ini['Rule_2'] = {};

    ini['Rule_2']['OutputIdx'] = 2;

     

    ini['Rule_3'] = {};

    ini['Rule_3']['OutputIdx'] = 2;

     

    for (let i=1; i<=100; i++){

    if (ini['Rule_' + i] == undefined) break;

     

    let PIdx = ini['Rule_' + i]['OutputIdx'];

    addRule (PIdx);

     

    elm = document.getElementsByClassName ('Rule_' + PIdx + '_DTValue');

    console.log (elm[elm.length - 1].value);

     

    elm[elm.length - 1].value = elm[elm.length - 1].value + ' ok';

    console.log (elm[elm.length - 1].value);

    }

    }

     

    load ();

    </script>

     


    Řešení dotazu:


    Odpovědi

    Řešení 1× (RadekXxX (tazatel))
    15.9.2022 10:56 chrono
    Rozbalit Rozbalit vše Re: Javascript neaktualizuje element
    Tá časť dest.innerHTML += ... "vymaže" zmenu vo value atribúte. Na pridanie nových elementov sa dá použiť niečo ako createElement + appendChild.
    Řešení 1× (RadekXxX (tazatel))
    15.9.2022 12:17 Petr
    Rozbalit Rozbalit vše Re: Javascript neaktualizuje element
    Nebo původnímu kódu více odpovídající

    dest.insertAdjacentHTML('beforeend', '...')
    16.9.2022 20:52 RadekXxX | skóre: 10
    Rozbalit Rozbalit vše Re: Javascript neaktualizuje element
    Aha, takze ono to neprida na konec, ale cely obsah to vymaze a znovu vlozi (predpokladam, ve stejnem stavu jak kdyz se prvky vytvarely) bez upravenych attribut prvku, to jsem netusil, diky.
    15.9.2022 11:41 z_sk | skóre: 34 | blog: analyzy
    Rozbalit Rozbalit vše Re: Javascript neaktualizuje element
    Prepis do objektovo, fakt to vyzerá krajšie a lepšie sa v tom orientuje a nie je to extra ťažke na naučenie:
    <script> class showRules { constructor(root) { let el=document.getElementById(root); el.innerHTML='
    '; this.root=root; } create_line(rule){ let line=document.createElement("div"); line.classList.add("line"); let el=document.createElement("span"); el.innerHTML=rule; line.append(el); el=document.createElement("button"); el.innerHTML="OK"; line.append(el); return line; } add_rule_1 (rule){ let section=document.getElementById(this.root+"_1"); let line=this.create_line(rule); section.append(line); } add_rule_2 (rule){ let section=document.getElementById(this.root+"_2"); let line=this.create_line(rule); section.append(line); } } shower=new showRules("show_rules"); shower.add_rule_1("test A"); shower.add_rule_1("test B"); shower.add_rule_2("test C"); <<script>
    Ak potrebuješ ukládať nejaké dáta k nejakému elementu, tak nemusíš ukladať do array, ale môžeš použiť .dataset v JS
    debian.plus@protonmail.com
    16.9.2022 20:58 RadekXxX | skóre: 10
    Rozbalit Rozbalit vše Re: Javascript neaktualizuje element
    Diky, ja jsem tridy vubec neresil, chtel jsem vlozit co nejjednodussi kod pro pochopeni. MJ. Jak vlozim takhle pekne formatovany kod do fora ? Zkousel jsem ruzny moznosti, ale psalo to bud chybu ze znacka "script" neni povolena nebo nejaky problem s TrueType fontem (nejsou si uplne jistej).
    16.9.2022 21:41 z_sk | skóre: 34 | blog: analyzy
    Rozbalit Rozbalit vše Re: Javascript neaktualizuje element
    <pre class="brush: html"><div>Hello world</div></pre>
    
    debian.plus@protonmail.com
    16.9.2022 23:57 RadekXxX | skóre: 10
    Rozbalit Rozbalit vše Re: Javascript neaktualizuje element

    Stejna chyba (znacka SCRIPT neni povolena) Jenom jsem mezi PRE vlozil SCRIPT

    <pre class="html brush:"><script></pre>

    17.9.2022 00:00 RadekXxX | skóre: 10
    Rozbalit Rozbalit vše Re: Javascript neaktualizuje element

    Oprava:

    <pre class="brush: html"><script></pre>

    17.9.2022 00:28 z_sk | skóre: 34 | blog: analyzy
    Rozbalit Rozbalit vše Re: Javascript neaktualizuje element
    Tak aj so script zapíseš:
    <pre class="brush: html">&lt;script>document.write("Hello world");&lt;/script></pre>
    A vystup:
    <pre class="brush: html"><script>document.write("Hello world");</script></pre>
    Znak < musíš zakódovať ako HTML entitu.
    debian.plus@protonmail.com
    17.9.2022 00:38 RadekXxX | skóre: 10
    Rozbalit Rozbalit vše Re: Javascript neaktualizuje element
    Super, dekuju, priste vyuziju

    Založit nové vláknoNahoru

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

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