Diskuze: Button disabled - aktivace po zapsání do input
V předchozím kvízu, Online test znalostí JavaScript, jsme si ověřili nabyté zkušenosti z kurzu.

Člen

Zobrazeno 6 zpráv z 6.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí JavaScript, jsme si ověřili nabyté zkušenosti z kurzu.
Řešení může vypadat třeba následovně.
function aktivuj(element, buttonid) {
let val = parseFloat(element.value);
let btn = buttonid !== undefined ? document.getElementById(buttonid) : element.nextElementSibling;
btn.disabled = isNaN(val) ? true : false;
}
Mysli na to, že input typu number má i tlačítka a nejde reagovat jen na onkeyup, ale musíš i na onchange.
<input type="number" onkeyup="aktivuj(this);" onchange="aktivuj(this);" value="" />
Celé v akci si to můžeš vyzkoušet tady včetně druhého volitelného parametru funkce https://jsfiddle.net/91am6s2w/
Pane, mnohokrát děkuji za velkou pomoc. Ale popravdě nevím, co jsi to
vlastně udělal.
Jinak jsem musel udělat úpravu a deklarovat aktivuj
Nastavil jsem
const aktivuj = (element, buttonid) => {
…
}
A funguje.
Ještě jednou díky.
Ahoj,
na začátek upozorňuji, že javascript jsem nikdy nedělal ale co takhle
<input type="number" onkeyup="activate(this, 'spust');" id="c1" class="cislo" name="cislo1" value="">
<button type="button" id="spust" name="spust" disabled>Spusť</button>
<input type="number" id="c2" class="cislo" onkeyup="activate(this, 'hadej')"; name="cislo2" value="">
<button type="button" id="hadej" name="hadej" disabled>Hádej</button>
a pak
function activate(number, btnId) {
let btn = document.getElementsById(btnId);
btn.disabled = number.values == ''
}
Nemáš zač a nehledej v tom žádné záhady. Po řádcích se v té metodě děje:
Jestě jednou díky.
Zobrazeno 6 zpráv z 6.