Curs Javascript

- 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
Ce atribut indica faptul ca un camp de formular trebuie completat?
required="required" autofocus="autofocus" placeholder="text"
<input type="text" name="name1" required="required" />
Ce metoda CSS misoreaza sau mareste dimensiunile unui element (inclusiv continutul)?
translate() scale() skew()
#some_id:hover {
  transform: scale(2, 1.5);
  -ms-transform: scale(2, 1.5);    /* IE 9 */
  -moz-transform: scale(2, 1.5);   /* Firefox */
}
Click pe metoda obiectului Date care returneaza ziua din luna.
setDate() getMonth() getDate()
var rightnow = new Date();
var day = rightnow.getDate();
alert(day);
Ce functie este folosita pentru a incarca un fisier pe server?
is_file() move_uploaded_file() fopen()
if(move_uploaded_file($_FILES["field_name"]["tmp_name"], "dir/file_name")) {
  echo "Fisierul a fost incarcat";
}
Cum se spune in engleza expresia: "Ploua cu galeata"?
rain cats and dogs rain buckets quiet rain
In Bucharest it`s raining cats and dogs.
- In Bucuresti ploua cu galeata.
Cum se spune in spaniola expresia: "Ploua cu galeata"?
llover cubo llover a cántaros lluvia tranquila
En Madrid está lloviendo a cántaros.
- In Madrid ploua cu galeata.
jQuery - Utilizare evenimente cu metoda on()

Last accessed pages

  1. Download carti electronice si programe pentru Limba Engleza (44734)
  2. Poezii pentru copii, in engleza (41468)
  3. Lucru cu fisiere 1 (1196)
  4. Pronumele personal (9411)
  5. Numere cardinale 1-10 (5119)

Popular pages this month

  1. Cursuri si Tutoriale: Engleza, Spaniola, HTML, CSS, Php-Mysql, JavaScript, Ajax (194)
  2. Coduri pt culori (104)
  3. Gramatica limbii engleze - Prezentare Generala (99)
  4. Gramatica limbii spaniole. Indrumator si prezentare generala (86)
  5. Cursuri limba engleza gratuite si lectii online (77)