Curs Javascript


Evenimentele reprezinta actiuni provocate de browser sau de vizitatorul paginii.
De exemplu: cand pagina incepe sa se incarce in fereastra are loc evenimentul "Load", daca vizitatorul apasa un buton din pagina se provoaca evenimentul "Click". Cand mouse-ul este deasupra unui element, se declanseaza un eveniment "mouseover".


O lista cu evenimente JavaScript organizate pe categorii gasiti la pagina de la adresa:
marplo.net/javascript/lista-evenimente-js


Atribute HTML pentru evenimente

JavaScript poate reactiona la evenimente cu ajutorul "event-handlers" (manageri sau gestionar de evenimente).
Handlerele de evenimente se pot adauga ca atribute in tag-urile HTML, folosind urmatoarea sintaxa.

<tag event='cod-JS'>
Unde 'event' reprezinta numele evenimentului, cu 'on' la inceput (onclick, onload, ..); iar 'cod-JS' poate fi in general o functie JavaScript care se executa la declansarea evenimentului respectiv.

- Exemplu, cand mouse-ul e pozitionat deasupra unui Div se apeleaza o functie care schimba culoarea 'background', iar cand se apasa clic pe acel Div se executa alta functie care adauga alt text in el.

Cuvantul this din cod reprezinta elementul pe care se actioneaza evenimentul, si e transmis ca argument la functia apelata.

<style>
#dv1 {
background:#b0deb0;
font-size:20px;
height:50px;
padding:3% 8px 5px 8px;
text-align:center;
width:120px;
}
</style>

<h4>Exemplu onmouseover si onclick</h4>
<div id='dv1' onmouseover='changeBgr(this)' onclick='changeTxt(this)'>Click Aici.</div>

<script>
function changeBgr(elm){
 elm.style.background ='#bebefe';
}

function changeTxt(elm){
 elm.innerHTML ='Pacea-i Buna.';
}
</script>
- Demo:
Click Aici.

Evenimentele pot fi utilizate si la elemente de formular.
Daca dorim sa apelam o functie de fiecare data cand se adauga ceva intr-o caseta <input>, se poate folosi evenimentul 'oninput'.
- Exemplu, cand se adauga caractere intr-o caseta de text, se apeleaza o functie care copie acel text in alt element HTML, si afiseaza numarul de caractere adaugate.

<h4>Exemplu oninput</h4>
<p>Cand se scrie ceva in caseta de text, e apelata o functie care afiseaza numarul de caractere si adauga textul la #resp.</p>
Text: <input type='text' value='Liniste' oninput='addTxt(this)'/>
<blockquote id='resp'>#resp</blockquote>

<script>
var resp = document.getElementById('resp');
function addTxt(elm){
 var txt = elm.value;
 resp.innerHTML ='<p>Nr. caractere: '+ txt.length +'</p>'+ txt;
}
</script>

Utilizare Evenimentele in cod JavaScript

Pentru a nu amesteca tag-urile HTML cu coduri JS, evenimentele se pot adauga in codul JavaScript, asociate la elementul HTML preluat in JS; folosind aceasta sintaxa.

function funcName(ev){
 // ev reprezinta obiectul cu evenimentul declansat
 //codul functiei
}

elm.event = funcName;
Unde elm reprezinta elementul HTML la care se adauga evenimentul 'event'.
La definire, functia funcName poate avea un parametru (aici 'ev'); si reprezinta obiectul cu evenimentul care apeleaza functia. Aceasta se apeleaza doar cu numele, fara paranteze rotunde.

• Sau cu functie anonima:
elm.event = function(ev){
 // ev reprezinta obiectul cu evenimentul declansat
 //codul functiei
};


Iata un exemplu util cu 'onkeyup'.
- Muta automat cursorul in urmatoarea caseta <input> atunci cand s-a completat tot campul precedent (cand se ajunge la lungimea 'maxlength').
<style>
#frm1 input {
background:#b0dfb0;
font-size:16px;
text-align:center;
width:50px;
}
#frm1 input:focus {
background:#ededaf;
}
</style>

<h4>Exemplu onkeyup</h4>
<p>Cursorul se muta automat in urmatoarea caseta de text cand s-a completat tot campul precedent (la lungimea 'maxlength' a campului, aici 4 caractere).</p>
<form id='frm1'>
 Adaugati text: <input maxlength='4' autofocus> / <input maxlength='4'> / <input maxlength='4'>
</form>

<script>
//functia apelata de onkeyup; primeste indexul de ordine al elementului in form
function nextElm(ev){
 var elm = ev.target; //elementul curent, care declanseaza evenimentul

 //daca lungimea textului din elm este egala cu maxlength
 if(elm.value.length == elm.maxLength) {
 var next = elm.tabIndex +1; //urmatorul input

 //daca nu e ultimul element, face focus la urmatorul
 if(next < frm1.length) frm1[next].focus();
 }
}

var frm1 = document.getElementById('frm1');

//parcurge elementele din frm1
for(var i=0; i<frm1.length; i++){
 frm1[i].tabIndex = i; //seteaza indexul de ordine la atribut 'tabindex'
 frm1[i].onkeyup = nextElm; //apeleaza functia nextElm la evenimentul onkeyup
}
</script>

Un Test simplu in fiecare zi

HTML
CSS
JavaScript
PHP-MySQL
Engleza
Spaniola
Ce atribut e folosit in tag-ul <a> pentru adresa link-ului?
src href rel
<a href="http://coursesweb.net/" title="CoursesWeb.net">CoursesWeb.net</a>
Ce proprietate CSS seteaza tipul fontului utilizat?
font-family text-decoration font-size
h2 {
  font-family:"Calibri", sans-serif;
}
Ce instructiune selecteaza toate tag-urile <div> cu class="cls"?
querySelector("div.cls") getElementsByTagName("div") querySelectorAll("div.cls")
var elm_list = document.querySelectorAll("div.cls");
var nr_elms = elm_list.length;       // numar elemente selectate
alert(nr_elms);
Indicati functia care returneaza suma valorilor dintr-un array.
array_sum() array_diff() array_shift()
$arr =[1, 2, 3, 4);
$arr_sum = array_sum($arr);
echo $arr_sum;       // 10
Indicati forma corecta a verbului "study" (a studia) la Trecutul Simplu in aceasta propozitie: "We (study) English."
studyed studys studied
We studied English.
- Noi am studiat engleza.
Indicati forma corecta a verbului "decir" (a spune) la Prezent in aceasta propozitie: "Yo (decir) siempre la verdad."
digas digo decir
Yo digo siempre la verdad.
- Eu spun mereu adevarul.
Evenimente JavaScript

Last accessed pages

  1. Alphabet and Pronunciation - Alfabetul si pronuntia in limba engleza (60138)
  2. Prepozitii - Prepositions (33763)
  3. Mini vocabular Englez-Roman (6423)
  4. Adverbele in limba engleza - Adverbs (32967)
  5. Numerale, Numere in limba engleza - Numerals (52823)

Popular pages this month

  1. Cursuri si Tutoriale: Engleza, Spaniola, HTML, CSS, Php-Mysql, JavaScript, Ajax (1125)
  2. Coduri pt culori (550)
  3. Cursuri limba engleza gratuite si lectii online (469)
  4. Gramatica limbii engleze - Prezentare Generala (445)
  5. Exercitii engleza - English Tests and exercises - Grammar (416)