Cuvintele speciale "this" si "target" pot fi utilizate in evenimente JavaScript pentru a obtine elementul asociat la evenimentul inregistrat.
- "this" - reprezinta obiectul la care a fost inregistrat evenimentul in codul javascript.
- "target" - e o proprietate pt evenimente. "e.target" este elementul care declanseaza evenimentul (pe care se executa actiunea).

• Ca sa puteti utiliza proprietatea "target" trebuie sa adaugati un parametru la functia cu evenimentul.
Sintaxa:
obiect.eveiment = function(e) {
  // aici se poate folosi e.target
}
"this" si "e.target" fac diferenta dintre obiectul la care este inregistrat evenimentul si elementul care-l declanseaza. De multe ori reprezinta acelasi element, dar nu mereu, in special cand se lucreaza cu elemente parinte si copil.
- Iata un exemplu. Un DIV #parinte cu un DIV #copil in el. Eveniment onclick inregistrat la #parinte, si se obtine ID-ul elementului returnat de "this" si "e.target".
<!doctype html>
<html lang="ro">
<head>
<meta charset="utf-8" />
<title>Exemplu this si target</title>
<style type="text/css">
#parinte {
 height: 7em;
 background: #00da01;
 padding: 1em;
}
#copil {
 height: 80%;
 margin: 0.5em 1.5em;
 background: #8889fe;
}
</style>
</head>
<body>

<div id="parinte">Parinte
 <div id="copil">Copil</div>
</div>
<script type="text/javascript">
document.getElementById('parinte').onclick = function(e) {
  var id1 = this.id;
  var id2 = e.target.id;
  alert('this = '+ id1 +'\n e.target = '+ id2);
}
</script>

</body>
</html>
Demo, clic pe Copil (dreptunghiul albastru), apoi pe Parinte (suprafata verde), si vedeti diferenta in fereastra alert.
Parinte
Copil
• Lucrul cu "this" si "e.target" in evenimente e util de exemplu cand se inregistreaza un eveiment la un obiect cu instructiuni care sa nu fie aplicate si la elementele copil. Sau cnd trebuie lucrat exact cu elementul pe care se declanseaza evenimentul (se preia cu "e.target").
- In urmatorul exemplu fereastra alert e afisata doar la clic pe DIV-ul Parinte.
<!doctype html>
<html lang="ro">
<head>
<meta charset="utf-8" />
<title>Exemplu this si target</title>
<style type="text/css">
#parinte {
 height: 7em;
 background: #00da01;
 padding: 1em;
}
#copil {
 height: 80%;
 margin: 0.5em 1.5em;
 background: #8889fe;
}
</style>
</head>
<body>

<div id="parinte">Parinte
 <div id="copil">Copil</div>
</div>
<script type="text/javascript">
document.getElementById('parinte').onclick = function(e) {
  if(this === e.target) {
    alert(this.id);
  }
}
</script>

</body>
</html>
Demo, clic pe Copil (dreptunghiul albastru), apoi pe Parinte (suprafata verde).
Parinte
Copil

Un Test simplu in fiecare zi

HTML
CSS
JavaScript
PHP-MySQL
Engleza
Spaniola
Ce tip de <input> creaza un camp de text care trebuie sa contina doar numere?
type="text" type="number" type="date"
<input type="number" name="points" min="5" max="80" />
Ce proprietate CSS permite modificarea transparentei unui element?
font-style opacity color
#id {
  filter:alpha(opacity=40);    /* for IE */
  opacity:0.4;
}
Clic pe functia care formateaza un numar la o anumita lungime de caractere.
toPrecision() exp() toFixed()
var num = 12.84567;
alert( num.toPrecision(3) );       // 12.8
Ce functie aranjeaza aleator elementele dintr-un array?
natsort() shuffle() sort()
$lang =[10=>"PHP", 20=>"JavaScript", "site"=>"coursesweb.net");
shuffle($lang);
var_export($lang);     // array (0=>"coursesweb.net", 1=>"PHP", 2=>"JavaScript")
Indicati Superlativul cuvantului "good" (bun).
better best goodest
She is the best in our class.
- Ea este cea mai buna din clasa noastra.
Care este Superlativul cuvantului "bueno" (bun)?
el mejor más bueno muy bueno
Él es el mejor en nuestra clase.
- El este cel mai bun din clasa noastra.
this si target in Evenimente

Last accessed pages

  1. Cursuri si Tutoriale: Engleza, Spaniola, HTML, CSS, Php-Mysql, JavaScript, Ajax (121220)
  2. Curs si Tutoriale JavaScript (50692)
  3. Sintaxa JavaScript (6199)
  4. Curs PHP MySQL, Tutoriale si Scripturi PHP (48329)
  5. Inregistrare, Afisare numar vizitatori si utilizatori Online (352)

Popular pages this month

  1. Cursuri si Tutoriale: Engleza, Spaniola, HTML, CSS, Php-Mysql, JavaScript, Ajax (846)
  2. Curs HTML gratuit Tutoriale HTML5 (615)
  3. Curs PHP MySQL, Tutoriale si Scripturi PHP (559)
  4. Curs si Tutoriale Ajax (556)
  5. Curs si Tutoriale JavaScript (553)