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 tag se foloseste pentru a include fisier extern CSS in pagina web?
<body> <script> <link>
<link href="/templ/style.css" rel="stylesheet" type="text/css" />
Ce proprietate CSS seteaza marimea textului?
font-weight text-decoration font-size
h2 {
  font-size: 1em;
}
Indicati proprietate JavaScript care poate sa adauge cod HTML intr-un element.
text value innerHTML
document.getElementById("someID").innerHTML = "Continut HTML";
Clic pe functia care returneaza numarul de caractere dintr-un sir in PHP.
count() strlen() stristr()
$str = "http://CoursesWeb.net/";
$nr_chr = strlen($str);
echo $nr_chr;       // 22
Care este forma de feminin a adjectivului "white" (alb)?
white whitea whites
(In limba engleza adjectivele au aceeasi forma pt. ambele genuri)
The snow is white. - Zapada e alba.
Care este forma de feminin a adjectivului "blanco" (alb)?
blanc blance blanca
La nieve es blanca.
- Zapada e alba.
jQuery - Utilizare evenimente cu metoda on()

Last accessed pages

  1. Sintaxa JavaScript (11093)
  2. Tutoriale JavaScript (3591)
  3. Verbe neregulate (5283)
  4. Cursuri si Tutoriale: Engleza, Spaniola, HTML, CSS, Php-Mysql, JavaScript, Ajax (271093)
  5. Limba spaniola curs online incepatori si avansati (29285)

Popular pages this month

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