JavaScript - 3. lekce
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu

JavaScript - 3. lekceJavaScript - 3. lekce

 
Hledat
Moderní platforma pro vytvoření vašeho nového webu – Wix.com.
Nyní už můžete mít web zdarma.
Vybavení pro Laser Game
Spuštěn Filmový magazín
Laser Game Brno
Laser Game Ostrava

JavaScript - 3. lekce

Google       Google       19. 1. 2006       26 372×

Události a funkce.

Reklama
Reklama

Události

Události reagují na akce konané uživatelem anebo internetovým prohlížečem. Uživatel například vykoná akci tím, že klikne kurzorem myši na určitou část na stránce, což můžeme zaznamenat událostí onClick, a reagovat na tuto akci skriptem. K internetovému prohlížeči se vztahují události jako je například onLoad (vykoná skript po načtení stránky). Podrobnější přehled událostí naleznete v příští lekci. Událost používáme jako atribut elementu, ke kterému se bude vztahovat. Srozumitelnější to bude z příkladu.

Do tagu <a> (odkaz) přidáme atribut onMouseOver, který obsahuje skript pro zavolání okna alert, což zaručí, že po přejetí odkazu kurzorem myši vyskočí právě okno alert s definovaným upozorněním.

<a href="stranka.htm" onMouseOver="alert('Test onMouseOver')">Odkaz</a>

Můžete si to sami vyzkoušet → Odkaz.

Cílem druhého příkladu je vytvořit tabulku, ve které se bude měnit pozadí jednotlivých řádků po najetí na ně myší a po opuštění se vrátí do původního stavu. Změnu můžeme definovat přímo v události pomocí objektu style, ale já jsem zvolil příjemnější metodu, kdy si vytvoříte 2 CSS třídy, které se ve vztahu s událostí budou pouze u daného elementu měnit.

<html>
  <head>
    <title>Titul</title>
    <style>
      .bila {background-color:"white"}
      .zluta {background-color:"yellow"}
    </style>
  </head>
  <body>
    <table border="2px">
      <tr class="bila" onMouseOver="this.className='zluta'" onMouseOut="this.className='bila'">
        <td>buňka</td>
        <td>buňka</td>
      </tr>
      <tr class="bila" onMouseOver="this.className='zluta'" onMouseOut="this.className='bila'">
        <td>buňka</td>
        <td>buňka</td>
      </tr>
    </table>
  </body>
</html>

Poznatky

  • V mnoha případech je potřeba používat styly, buď předem definované do tříd, nebo měněné pomocí objektu style
  • onmouseover – událost po nejetí kurzoru myši na objekt
  • onmouseout – událost po odjetí kurzoru myši z objektu
  • this – tento příkaz říká skriptu, že se bude manipulovat právě s elementem, ve kterém je obsažen
  • className – definuje změnu použité třídy na element

Funkce

Funkce jsou pro JavaScript velmi důležité a budete se s nimi setkávat pořád. Použít funkci je výhodné v případě, že potřebujete aplikovat určité příkazy na více místech. Například potřebujete zjistit u několika inputů (textová pole), zdali obsahuje každý nějaké určité slovo. Proto si definujete jednu funkci, která se skládá z klíčového slova function, dále názvu funkce, vstupních hodnot a těla funkce, kde je definováno, co bude dělat. V této lekci vám ukážu základní podobu funkce na příkladu, kdy funkce vypíše pokaždé po zavolání stejný text, ve kterém se bude měnit akorát vstupní hodnota.

Do hlavičky stránky zapíšeme:

<script language="JavaScript" type="text/javascript">
 function text(jmeno){
  document.write("Rád tě tu zase vidím, ");
  document.write(jmeno);
 }
</script>

A do těla stránky následující:

<script language="JavaScript" type="text/javascript">
 text("Pepo.");
 text("Mařenko.");
 text("Frantíku.")
</script>

Výsledkem je:

Rád tě tu zase vidím, Pepo.
Rád tě tu zase vidím, Mařenko.
Rád tě tu zase vidím, Frantíku.

Poznatky

  • function – klíčové slovo, říká, že se jedná o funkci
  • text – název funkce
  • (jmeno) – v závorce za názvem funkce jsou ony vstupní údaje (nemusí tam být, pokud funkce nepracuje s nějakými externími daty)
  • text("Pepo."); – vlastní volání funkce, prvně se píše název funkce, kterou voláme, a do závorky vstupní údaje pro tuto volanou funkci

Úkol

Napište mi kód, kde bude výsledkem: "Sekačka značky Mountfield má vysoký počet otáček. Sekačka značky neznámé má vysoký počet otáček." Slova 'Mountfield' a 'neznámé' budou hodnotami funkce (proměnnými), ostatní text bude funkcí. Pod to udělejte odkaz, který bude házet alert po odjetí kurzoru myši.

×Odeslání článku na tvůj Kindle

Zadej svůj Kindle e-mail a my ti pošleme článek na tvůj Kindle.
Musíš mít povolený příjem obsahu do svého Kindle z naší e-mailové adresy kindle@programujte.com.

E-mailová adresa (např. novak@kindle.com):

TIP: Pokud chceš dostávat naše články každé ráno do svého Kindle, koukni do sekce Články do Kindle.

Hlasování bylo ukončeno    
0 hlasů
Google
(fotka) Tomáš BobekAutor je designérem stránek (2D grafika), ovládá jazyky HTML, CSS, PHP, JavaScript a zajímá se o programování v Javě.Krom programujte.com se podílí na projektech maths.cz (jako redaktor a grafik), ceskewebstudio.cz (jako designér) a webber.cz (jako JavaScript scriptař). Ostatní volný čas rád tráví s přáteli nebo sportuje (tenis, nohejbal, hokejbal, závodně fotbal).
Web     Twitter     Facebook    

Nové články

Obrázek ke článku Ericsson ConsumerLab Report: rozšířená realita je další úrovní gamingu

Ericsson ConsumerLab Report: rozšířená realita je další úrovní gamingu

Celkem 66 % uživatelů zajímá rozšířená realita v oblasti gamingu. Mezi nimi je i 35 % těch, kteří jinak hry nehrají.
Pro téměř 50 % respondentů by bylo zajímavé zapojení virtuální objektů do reálného světa. Objekty by zůstaly tam, kde je při hře „umístili“.
Až 43 % uživatelů láká využití rozšířené reality ve sportu

Reklama
Reklama
Obrázek ke článku Instalace nejnovější verze Apache 2.4, PHP 7.3, MariaDB 10.3 a Memcached na Windows 10

Instalace nejnovější verze Apache 2.4, PHP 7.3, MariaDB 10.3 a Memcached na Windows 10

Buďte při vývoji efektivní! Pomocí tohoto návodu během chvíle vytvoříte ze svého počítače lokální webový server. Vyzbrojíte jej vším, co budete při práci potřebovat: Apache 2.4, PHP 7.3, MariaDB 10.3 a Memcached. Je to plná polní pro webové vývojáře s Windows 10. Navíc poradíme, jak mít na localhostu více projektů pomocí VirtualHost.

Obrázek ke článku Do poskytovatele managed hostingových služeb vshosting~ vstupují zahraniční investoři

Do poskytovatele managed hostingových služeb vshosting~ vstupují zahraniční investoři

Po více než roce jednání do vshosting~ vstoupili 3 investiční skupiny z Německa: Pecunalta, BrainWeb Investment a Quines Capital. Jde o investiční skupiny, které mají účast na projektech jako PlusServer (největší managed provider v Německu a jeden z největších v Evropě), PLESK, cPanel, CloudLinux, GoDaddy (největší světový hostingový poskytovatel z USA), či Acronis, pomohou vshosting~ v jeho plánované mezinárodní expanzi na další zahraniční trhy. Ve vshosting~ nyní drží 75% podíl, zbylých 25 % zůstává zakladatelům vshosting~, kterými jsou Damir Špoljarič (CEO) a Jan Martinů (CTO).

Obrázek ke článku Posuňte své znalosti IT na výrazně vyšší úroveň

Posuňte své znalosti IT na výrazně vyšší úroveň

Zájem o IT odborníky je v současnosti v tuzemsku i v zahraničí enormní a vedení firem si moc dobře uvědomuje, jak těžké je získat ty správné. I přesto, že je odborníků na trhu dlouhodobý nedostatek, stále platí, že část z nich je - a bude - placena výrazně lépe než ti ostatní. Proč tedy nebýt mezi nimi?

Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032019 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý