5. díl - Cykly v JavaScriptu

JavaScript Základní konstrukce Cykly v JavaScriptu

V minulém tutoriálu našeho seriálu jsme se naučili programovat podmínky v JavaScriptu. V dnešním dílu se budeme věnovat cyklům.

Cykly

Cykly spolu s podmínkami tvoří základ každého programovacího jazyka. Jak již slovo cyklus napoví, něco se bude opakovat. Když chceme v programu něco udělat 100x, jistě nebudeme psát pod sebe 100x ten samý kód, ale vložíme ho do cyklu. Cyklů máme několik druhů, vysvětlíme si, kdy který použít. Samozřejmě si ukážeme praktické příklady.

FOR cyklus

Tento cyklus má stanovený pevný počet opakování a hlavně obsahuje tzv. řídící proměnnou (celočíselnou), ve které se postupně během běhu cyklu mění hodnoty. Syntaxe (zápis) cyklu for je následující:

for (promenna; podminka; prikaz)
  • promenna je řídící proměnná cyklu, které nastavíme počáteční hodnotu (nejčastěji 0, protože v programování vše začíná od nuly, nikoli od jedničky). Např. tedy var i = 0.
  • podminka je podmínka vykonání dalšího kroku cyklu. Jakmile nebude platit, cyklus se ukončí. Podmínka může být např (i < 10).
  • prikaz nám říká, co se má v každém kroku s řídící proměnnou stát. Tedy zda se má zvýšit nebo snížit. K tomu využijeme speciálních příkazů ++ a --, ty samozřejmě můžete používat i úplně běžně mimo cyklus, slouží ke zvýšení nebo snížení proměnné o 1.

Pojďme si udělat jednoduchý příklad, většina z nás jistě zná Sheldona z The Big Bang Theory. Pro ty co ne, budeme simulovat situaci, kdy klepe na dveře své sousedky. Vždy 3x zaklepe a poté zavolá: "Penny!". Náš kód by bez cyklů vypadal takto:

document.write("Knock<br />");
document.write("Knock<br />");
document.write("Knock<br />");
document.write("Penny!");

My ale už nic nemusíme otrocky opisovat:

for (var i=0; i < 3; i++)
{
        document.write("Knock<br />");
}
document.write("Penny!");
Ukázka for cyklu v JavaScript – Knock, knock, knock, Penny!

Cyklus proběhne 3x, zpočátku je v proměnné i nula, cyklus vypíše "Knock" a zvýší proměnnou i o jedna. Poté běží stejně s jedničkou a dvojkou. Jakmile je v i trojka, již nesouhlasí podmínka i < 3 a cyklus končí. O vynechávání složených závorek platí to samé, co u podmínek. V tomto případě tam nemusí být, protože cyklus spouští pouze jediný příkaz. Nyní můžeme místo trojky napsat do deklarace cyklu desítku. Příkaz se vypíše 10x aniž bychom psali něco navíc. Určitě vidíte, že cykly jsou mocným nástrojem.

Zkusme si nyní využít toho, že se nám proměnná inkrementuje. Vypišme si čísla od jedné do deseti do seznamu.

document.write("<ul>");
for (var i = 1; i <= 10; i++)
        document.write("<li>" + i);
document.write("</ul>");

Výsledek:

For cyklus v JavaScriptu

Vidíme, že řídící proměnná má opravdu v každé iteraci (průběhu) jinou hodnotu. Všimněte si, že v cyklu tentokrát nezačínáme na nule, ale můžeme nastavit počáteční hodnotu 1 a koncovou 10. V programování je ovšem zvykem začínat od nuly, později zjistíme proč. Mezeru za každé číslo připojujeme jako text pomocí operátoru plus.

Nyní si vypíšeme malou násobilku (násobky čísel 1 až 10, vždy do deseti). Stačí nám udělat cyklus od 1 do 10 a proměnnou vždy násobit daným číslem. K výpisu hodnot využijeme tabulku. Mohlo by to vypadat asi takto:

document.write('<table border="1"><tr>');
for (var i = 1; i <= 10; i++)
        document.write("<td>" + i + "</td>");
document.write("</tr><tr>");
for (var i = 1; i <= 10; i++)
        document.write("<td>" + i * 2 + "</td>");
document.write("</tr><tr>");
for (var i = 1; i <= 10; i++)
        document.write("<td>" + i * 3 + "</td>");
document.write("</tr><tr>");
for (var i = 1; i <= 10; i++)
        document.write("<td>" + i * 4 + "</td>");
document.write("</tr><tr>");
for (var i = 1; i <= 10; i++)
        document.write("<td>" + i * 5 + "</td>");
document.write("</tr><tr>");
for (var i = 1; i <= 10; i++)
        document.write("<td>" + i * 6 + "</td>");
document.write("</tr><tr>");
for (var i = 1; i <= 10; i++)
        document.write("<td>" + i * 7 + "</td>");
document.write("</tr><tr>");
for (var i = 1; i <= 10; i++)
        document.write("<td>" + i * 8 + "</td>");
document.write("</tr><tr>");
for (var i = 1; i <= 10; i++)
        document.write("<td>" + i * 9 + "</td>");
document.write("</tr><tr>");
for (var i = 1; i <= 10; i++)
        document.write("<td>" + i * 10 + "</td>");
document.write("</tr></table>");
Malá násobilka pomocí dvou for cyklů v JavaScriptu

Program funguje hezky, ale pořád jsme toho dost napsali. Pokud vás napadlo, že v podstatě děláme 10x to samé a pouze zvyšujeme číslo, kterým násobíme, máte pravdu. Nic nám nebrání vložit 2 cykly do sebe:

document.write('<table border="1">');
for (var j = 1; j <= 10; j++)
{
        document.write("<tr>");
        for (var i = 1; i <= 10; i++)
                document.write("<td>" + i * j + "</td>");
        document.write("</tr>");
}
document.write("</table>");

Poměrně zásadní rozdíl, že? Pochopitelně nemůžeme použít u obou cyklů i, protože jsou vložené do sebe. Proměnná j nabývá ve vnějším cyklu hodnoty 1 až 10. V každé iteraci (rozumějte průběhu) cyklu je poté spuštěn další cyklus s proměnnou i. Ten je nám již známý, vypíše násobky, v tomto případě násobíme proměnnou j. Každý průběh vnitřního cyklu je třeba vložit do řádku tabulky, tedy do tagů <tr> a </ tr>.

Udělejme si ještě jeden program, na kterém si ukážeme práci s vnější proměnnou. Aplikace bude umět spočítat libovolnou mocninu libovolného čísla:

var a = 2; // Základ mocniny
var n = 3; // Exponent

var vysledek = a;
for (var i = 0; i < (n - 1); i++)
{
        vysledek = vysledek * a;
}

document.write("Výsledek: " + vysledek);

Asi všichni tušíme, jak funguje mocnina. Pro jistotu připomenu, že například 23 = 2 * 2 * 2. Tedy an spočítáme tak, že n-1 krát vynásobíme číslo a číslem a. Výsledek si samozřejmě musíme ukládat do proměnné. Zpočátku bude mít hodnotu a a postupně se bude v cyklu pronásobovat. Pokud jste to nestihli, máme tu samozřejmě článek s algoritmem výpočtu libovolné mocniny. Vidíme, že naše proměnná vysledek je v těle cyklu normálně přístupná. Pokud si však nějakou proměnnou založíme v těle cyklu, po skončení cyklu zanikne a již nebude přístupná.

Výsledek:

Mocnina v JavaScirptu pomocí for cyklu

Už tušíme, k čemu se for cyklus využívá. Zapamatujme si, že je počet opakování pevně daný. Do proměnné cyklu bychom neměli nijak zasahovat ani dosazovat, program by se mohl tzv. zacyklit, zkusme si ještě poslední, odstrašující příklad:

// tento kód je špatně
for (var i = 1; i <= 10; i++)
        i = 1;

Au, vidíme, že program se zasekl. Cyklus stále inkrementuje proměnnou i, ale ta se vždy sníží na 1. Nikdy tedy nedosáhne hodnoty > 10, cyklus nikdy neskončí a stránka se stále načítá. Záložku musíme zavřít.

While cyklus

While cyklus funguje jinak, jednoduše opakuje příkazy v bloku dokud platí podmínka. Syntaxe cyklu je následující:

while (podminka)
{
        // příkazy
}

Pokud vás napadá, že lze přes while cyklus udělat i FOR cyklus, máte pravdu :) FOR je vlastně speciální případ while cyklu. While se ale používá na trochu jiné věci, často máme v jeho podmínce např. metodu vracející logickou hodnotu true/false. Původní příklad z for cyklu bychom udělali následovně pomocí while:

var i = 1;
while (i <= 10)
{
        document.write(i + " ");
        i++;
}

To ale není ideální použití while cyklu. K tomuto druhu cyklu se ještě vrátíme. Příště nás čeká datová struktura pole.


 

Stáhnout

Staženo 105x (2.9 kB)
Aplikace je včetně zdrojových kódů v jazyce JavaScript

 

  Aktivity (1)

Článek pro vás napsal David Čápka
Avatar
Autor pracuje jako softwarový architekt a pedagog na projektu ITnetwork.cz (a jeho zahraničních verzích). Velmi si váží svobody podnikání v naší zemi a věří, že když se člověk neštítí práce, tak dokáže úplně cokoli.
Unicorn College Autor se informační technologie naučil na Unicorn College - prestižní soukromé vysoké škole IT a ekonomie.

Jak se ti líbí článek?
Celkem (4 hlasů) :
55555


 


Miniatura
Předchozí článek
Cvičení k 4. lekci JavaScriptu
Miniatura
Všechny články v sekci
Základní konstrukce jazyka JavaScript
Miniatura
Následující článek
Cvičení k 5. lekci JavaScriptu

 

 

Komentáře

Avatar
dr.jalo2
Člen
Avatar
dr.jalo2:

Alternativa k mocnine. Funguje pre nulu aj zaporne cisla.

var a = 2; // Základ mocniny
var n = 3; // Exponent
n= prompt("Zadaj exponent pre zaklad 2 ");
var vysledek = 1;
for (var i = 0; i < Math.abs(n); i++)
{
    vysledek = (n>0)? (vysledek * a) : (vysledek /a) ;
}
document.write("<br/> Mocnina "+a+" na "+n+" = "+vysledek+"<br/>");
 
Odpovědět  +1 13.1.2015 20:10
Avatar
asanos
Člen
Avatar
asanos:

Mám pro vás menší tip. Každý z vás už určitě někdy použil cyklus FOR pro procházení pole... a věřím, že kód který jste pro to použili byl podobný tomuhle:

for(var i=0; i < pole.length; i++){
  //udělej něco s i-tým prvkem pole
}

Problémem je, že při každém průchodu cyklem se musí znovu spočítat velikost daného pole, jestli se náhodou nějak nezměnilo. Což je pomalé.
____
Pokud nebudeme měnit velikost pole uvnitř daného cyklu, můžeme si dovolit následující způsob.

for(var i=0, length=pole.length; i < length; i++){
  //udělej něco s i-tým prvkem pole
}

Délka se vypočítá pouze jedenkrát na začátku, tzn. mnohem rychlejší ;)

Odpovědět  +2 15.6.2015 21:16
Na světě je 10 typů lidí. Ti, kteří rozumí binárce a ti co nerozumí.
Avatar
Odpovídá na asanos
Michal Žůrek (misaz):

tolikrát rychlejší to teda není, navíc je to méně přehledné (protože nejpoužívanější cykl, nejen na pole, je ten první tebou zmíněný). Navíc na to existuje forEach, když už tedy chceme být důslednější...

pole.forEach(function (item) {
    // zpracování položky
});
Odpovědět 15.6.2015 21:21
Nesnáším {}, proto se jim vyhýbám.
Avatar
asanos
Člen
Avatar
asanos:

ok ok :D to máš asi pravdu ;)

test forEachu jsem nenašel...

http://jsperf.com/…ray-length/4

Odpovědět 15.6.2015 22:10
Na světě je 10 typů lidí. Ti, kteří rozumí binárce a ti co nerozumí.
Avatar
ra3sk
Člen
Avatar
ra3sk:
document.write("<ul>");
for (var i = 1; i <= 10; i++)
        document.write("<li>" + i);
document.write("</ul>");

jak je možné, že to <li> sa samo aj zavrie... respektíve to nespôsobí error?

 
Odpovědět 11. října 20:10
Avatar
Pavol Hejný
Redaktor
Avatar
Odpovídá na ra3sk
Pavol Hejný:

HTML je hrozně "tolerantní" na chyby. Není potřeba, aby bylo tak přísné, protože je často zcela zjevné, jak chybu opravit, protože každy tag v sobě nese určitý význam:

<table>
<tr>
<td>A
<td>B
<tr>
<td>C
<td>D
</table>

Zatímco v programovacím jazyce to nejde automaticky:

for(let y=0;y<2;y++){
for(let x=0;x<2;x++){

for(let x=0;x<2;x++){

}

Tohle se dá doplnit jako 2 nebo 3 for v sobě.

Ale pochopitelně neuzavírat značky v html je prasárna

Editováno 12. října 12:26
Odpovědět  +1 12. října 12:24
http://pavolhejny.cz/
Avatar
ra3sk
Člen
Avatar
Děláme co je v našich silách, aby byly zdejší diskuze co nejkvalitnější. Proto do nich také mohou přispívat pouze registrovaní členové. Pro zapojení do diskuze se přihlas. Pokud ještě nemáš účet, zaregistruj se, je to zdarma.

Zobrazeno 7 zpráv z 7.