- Inregistrare eveniment pt. elemente adaugate dinamic
- Inregistrare evenimente sa se emita o singura data
- Stergere eveniment

Inregistrare Evenimente

Metoda jQuery .on() raspunde la orice eveniment atasat la elementul selectat.
Sintaxa:
element.on('event_name', function(eventObject){
 //your code...
});
- event_name - numele evenimentului (click, hover, change, input, etc..).
- eventObject - obiect cu elementul care actioneaza evenimentul. Aplicati: console.table(eventObject) in functia evenimentului si vedeti in consola din browser un tabel cu proprietatile acelui obiect.

Exemplu: Cand se apasa clic pe Div-urile cu clasa css 'ev_cls', va afisa un alert cu continutul Div-ului.
<div class='ev_cls'>What appears and disappears is not real.</div>
<div class='ev_cls'>Forgiveness is the real cure.</div>
<script>
$('.ev_cls').on('click', function(ev){
 alert($(this).html());
});
</script>
Demo, clic pe fiecare text.
What appears and disappears is not real.
Forgiveness is the real cure.

Inregistrare mai multe evenimente in aceeasi metoda

Metoda .on() care poate contine mai multe evenimente si functii callback. Astfel, se pot inregistra mai multe evenimente pentru acelasi selector in metoda .on().
$('div').on({
 mouseenter: function(){
 console.log('hovered over a div');
 },
 mouseleave: function(){
 console.log('mouse left a div');
 },
 click: function(){
 console.log('clicked on a div');
 }
});

Transmitere date la functia callback

Se poate transmite un obiect cu date (ca al doilea argument) care va fi adaugat in obiectul evenimentului. Obiectul transmis va fi adaugat in proprietatea eventObject.data.
$('div').on('click', {prop:'value'}, function(ev){
 console.log('event data:'+ ev.data.prop +' (should be "value")');
});

Inregistrare eveniment pt. elemente adaugate dinamic

Metoda jQuery .on() permite sa inregistrati evenimente care vor fi emise si la noi elemente adaugate dinamic.
In mod normal, evenimentul se inregistreaza la elementele care sunt prezente cand se face inregistrarea.
Sa vedem un exemplu:
<ul id='list'>
<li>Item #1</li>
<li>Item #2</li>
</ul>

<script>
//when click on the LI in #list, alert clicked LI content
$('#list li').on('click', function(ev){
 alert($(this).html());
});

//automatically append another LI in #list
$('#list').append('<li>Appended Item #3</li>');
</script>
In codul de sus, cand se apasa clic pe un LI din #list, este afisat continutul acelui LI.
Dar cand se adauga dinamic inca un LI in #list (Appended Item #3), la clic pe el nu se intampla nimic, deoarece inregistrarea s-a facut direct pentru elementele "#list li", care nu stie de ceea ce va fi adaugat in viitor.

- Demo, clic pe fiecare text:
- Pentru ca evenimentul sa se emita si la noile elemente adaugate dinamic, se foloseste o tehnica denumita "event delegation".
Se aplica evenimentul la metoda parinte (aici #list), apoi, selectorul pentru elementele copil (aici 'li') se adauga ca al doilea argument in metoda .on().
<script>
//when click on #list, alert its clicked LI content, even newly LI
$('#list').on('click', 'li', function(ev){
 alert($(this).html());
});

//automatically append another LI in #list
$('#list').append('<li>Appended Item #3</li>');
</script>
Evenimentu 'click' aplicat la #list va urmari clic-urile pe elementele copil 'li', inclusiv cele care vor fi adaugate in viitor.

- Demo: acum dati clic pe "Item #3".

Inregistrare evenimente sa se emita o singura data

Daca vreti sa inregistrati un eveniment care sa fie emis o singura data, folositi metoda .one().
- Exemplu: cand se apoasa clic pe un buton #ex_btn, functia atasata se executa doar la primul clic.
<button id='ex_btn'>Click</button>

<script>
$('#ex_btn').one('click', function(ev){
 alert('Next clik will not be emitted');
});
</script>
Demo:
Metoda .one() accepta aceleasi argumente ca si .on(); suporta evenimente multiple, transmitere date la eventObject, si event-delegation.

Stergere eveniment

Daca vreti sa stergeti inregistrarea unui eveniment, folositi metoda .off().
- Exemplu: dupa ce se da clic de doua ori pe #c2_btn, evenimentul 'click' la acel selector este anulat.
<button id='c2_btn'>Click</button>

<script>
var c2_nrc =0;
$('#c2_btn').on('click', function(ev){
 c2_nrc++;
 $(this).text('Clicks: '+ c2_nrc);

 if(c2_nrc ==2) $('#c2_btn').off('click'); //removes the click
});
</script>
Demo, clic de doua ori pe urmatorul buton. A treia oara clic-ul nu va fi emis:

Un Test simplu in fiecare zi

HTML
CSS
JavaScript
PHP-MySQL
Engleza
Spaniola
Care tag se foloseste in <table> pentru a crea celula de tip "header"?
<thead> <th> <td>
<table><tr>
  <th>Title 1</th>
  <th>Title 2</th>
</tr></table>
Ce proprietate CSS seteaza distanta dintre randuri?
line-height word-spacing margin
.some_class {
  line-height: 150%;
}
Care functie deschide o noua fereastra.
alert() confirm() open()
document.getElementById("id_button").onclick = function(){
  window.open("http://coursesweb.net/");
}
Indicati functia PHP care returneaza un array cu numele fisierelor si directoarelor dintr-un director.
mkdir() scandir() readdir()
$ar_dir = scandir("dir_name");
var_export($ar_dir);
Care din urmatoarele forme a verbului "sleep" (a dormi) se foloseste pentru viitor?
sleeping slept will sleep
He will sleep there.
- El va dormi acolo.
Care din urmatoarele forme a verbului "dormir" (a dormi) se foloseste pentru viitor?
dormido dormirá durmiendo
Él dormirá allí.
- El va dormi acolo.
jQuery - Utilizare evenimente cu metoda on()

Last accessed pages

  1. Cursuri limba engleza gratuite si lectii online (1341)
  2. Prezentul simplu - Exercitii si teste incepatori (698)
  3. Jocuri Zuma (1513)
  4. Butterfly Kyodai (2101)
  5. Zuma Deluxe (2025)

Popular pages this month

  1. Bubbles3 (3301)
  2. Gramatica limbii engleze - Prezentare Generala (2644)
  3. Prezentul simplu si continuu - Present Tense Simple and Continuous (2358)
  4. Butterfly Kyodai (2101)
  5. Zuma Deluxe (2025)