abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 19:00 | Zajímavý projekt

    Na crowdsourcingové platformě Crowd Supply byla spuštěna kampaň na podporu open source biometrického monitoru ve tvaru hodinek HealthyPi Move. Cena je 249 dolarů a plánovaný termín dodání listopad letošního roku.

    Ladislav Hagara | Komentářů: 11
    24.5. 22:22 | Upozornění Ladislav Hagara | Komentářů: 9
    24.5. 17:44 | Nová verze

    Firma Murena představila /e/OS verze 2.0. Jde o  alternativní sestavení Androidu bez aplikací Google. Mezi novinkami je podrobnější nastavení ochrany soukromí před sledováním aplikacemi. Murena prodává několik smartphonů s předinstalovaným /e/OS (Fairphone, repasovaný Google Pixel 5).

    Fluttershy, yay! | Komentářů: 0
    24.5. 14:33 | Zajímavý software

    Do 30. května lze v rámci akce Warhammer Skulls 2024 získat na Steamu zdarma hru Warhammer 40,000: Gladius - Relics of War.

    Ladislav Hagara | Komentářů: 1
    24.5. 13:33 | Nová verze

    HelenOS (Wikipedie), tj. svobodný operační systém českého původu založený na architektuře mikrojádra, byl vydán ve verzi 0.14.1. Přehled novinek v poznámkách k vydání. Vypíchnou lze nabídku Start. Videopředstavení na YouTube.

    Ladislav Hagara | Komentářů: 3
    23.5. 23:22 | Zajímavý software

    BreadboardOS je firmware pro Raspberry Pi Pico (RP2040) umožňující s tímto MCU komunikovat pomocí řádkového rozhraní (CLI). Využívá FreeRTOS a Microshell.

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

    Vývojáři KDE oznámili vydání balíku aplikací KDE Gear 24.05. Přehled novinek i s náhledy a videi v oficiálním oznámení. Do balíku se dostalo 5 nových aplikací: Audex, Accessibility Inspector, Francis, Kalm a Skladnik.

    Ladislav Hagara | Komentářů: 13
    23.5. 12:55 | Nová verze

    Byla vydána (𝕏) nová verze 18.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
    22.5. 23:44 | Pozvánky

    V neděli 26. května lze navštívit Maker Faire Rychnov nad Kněžnou, festival plný workshopů, interaktivních činností a především nadšených a zvídavých lidí.

    Ladislav Hagara | Komentářů: 0
    22.5. 16:33 | Nová verze

    Byla vydána nová stabilní verze 3.20.0, tj. první z nové řady 3.20, minimalistické linuxové distribuce zaměřené na bezpečnost Alpine Linux (Wikipedie) postavené na standardní knihovně jazyka C musl libc a BusyBoxu. Z novinek lze vypíchnou počáteční podporu 64bitové architektury RISC-V.

    Ladislav Hagara | Komentářů: 0
    Podle hypotézy Mrtvý Internet mj. tvoří většinu online interakcí boti.
     (87%)
     (3%)
     (5%)
     (5%)
    Celkem 761 hlasů
     Komentářů: 16, poslední 14.5. 11:05
    Rozcestník

    Dotaz: Javascript neaktualizuje element

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

    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: 9
    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: 9
    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: 9
    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: 9
    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: 9
    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.