Curs Javascript

Acest tutorial arata cum se lucreaza cu legaturile parinte (parent) si copii (children) in jQuery.
- parent se refera la elementul parinte in care este inclus direct alt element, denumit copil (child).
De exemplu, in acest cod HTML:

<div id="parent_tag">
 <p id="child_tag">Text oarecare...</p>
 <span>Alt element copil in "parent_tag".</span>
</div>
- DIV-ul ("parent_tag") este elementul parinte pentru paragraf (<p>) si <span>. Tag-ul <p> si <span> sunt copii al lui "parent_tag" (DIV-ul).

jQuery parent()

Aceasta metoda preia elementul parinte al fiecarui element din setul curent de obiecte selectate.
Sintaxa:
obiect_jQuery.parent(selector)
- obiect_jQuery - reprezinta un set de elemente selectate in obiectul DOM.
- "selector" - este optional, si reprezinta un sir cu selector care sa filtreze elementul parinte selectat.

Exemplu, la clic pe un buton va fi afisata o fereastra alert cu ID-ul tag-ului parinte a imaginii cu class="clsim".
<div id="thediv">
 <p id="the_p">
  <img src="imgs/javascript.gif" alt="Curs JavaScript" class="clsim" width="200" height="30" />
 </p>
 <button id="btn">Click</button>
</div>

<script type="text/javascript"><!--
$(document).ready(function() {
  // la clic pe #btn
  $('#btn').click(function(){
    // preia ID-ul elementului parinte al lui ".clsim"
    var idpr = $('.clsim').parent().attr('id');
    alert('ID-ul elementului parinte al imaginii e:\n'+ idpr);
  });
});
--></script>

Demo:

Curs JavaScript


Un alt exemplu, cu un selector la metoda parent(), ca sa filtreze rezultatele.
- Adauga o culoare de fundal (background) la parintele fiecarui tag <a> (doar la parintele cu class="clsli").
<ul>
 <li class="clsli"><a href="https://marplo.net/javascript/" title="Curs JavaScript">Curs JavaScript</a></li>
 <li><a href="https://marplo.net/html/" title="Curs HTML">Curs HTML</a></li>
 <li class="clsli"><a href="http://www.coursesweb.net/jquery/jquery-course" title="Curs jQuery">Curs jQuery</a></li>
</ul>
<button id="btn2">Click</button>

<script type="text/javascript"><!--
$(document).ready(function() {
  // la clic pe #btn2
  $('#btn2').click(function(){
    $('a').parent('.clsli').css('background', '#08ed09');
  });
});
--></script>

Demo:

• Daca doriti sa obtineti parintele elementului parinte, se foloseste aceasta sintaxa:
obiect_jQuery.parent().parent()

jQuery children()

Obtine elementele copil aflate direct in fiecare obiect din setul selectat.
Sintaxa:
obiect_jQuery.children(selector)
- obiect_jQuery - reprezinta un set de elemente selectate in obiectul DOM.
- "selector" - este optional, si reprezinta un sir cu selector care sa filtreze "copii" selectati.

Exemplu, schimba culoarea textului la copii din fiecare <li> (doar la copii cu class="clsa").
<ul>
 <li><a href="https://marplo.net/javascript/" title="Curs JavaScript" class="clsa">Curs JavaScript</a></li>
 <li><a href="https://marplo.net/html/" title="Curs HTML">Curs HTML</a></li>
 <li><a href="http://www.coursesweb.net/jquery/jquery-course" title="Curs jQuery" class="clsa">Curs jQuery</a></li>
</ul>
<button id="btn3">Click</button>

<script type="text/javascript"><!--
$(document).ready(function() {
  // la clic pe #btn3
  $('#btn3').click(function(){
    $('li').children('.clsa').css('color', '#fe0001');
  });
});
--></script>

Demo:


• jQuery are si selectori care pot fi utilizati in relatia parinte-copil, precum :nth-child() si parent > child.

Selectorul :nth-child()

Selectorul :nth-child(n) selecteaza elementele care sunt al n-lea copil in parintele lor.
Sintaxa:
$(selector:nth-child(n))
Aceasta pseudo-clasa este derivata din CSS. Index-ul (n) incepe cu 1 pentru primul copil.

Exemplu, adauga un chenar in jurul imaginii cu index de ordine "ni" din DIV-ul cu id="iddv". Index-ul "ni" este marit cu o unitate la fiecare clic.
<div id="iddv">
 <img src="imgs/circle.gif" alt="Cerc" width="29" height="30" />
 <img src="imgs/rhomb.gif" alt="Romb" width="37" height="30" />
 <img src="imgs/triangle.gif" alt="Triunghi" width="36" height="32" />
</div>
<button id="btn4">Click</button>

<script type="text/javascript"><!--
$(document).ready(function() {
  var ni = 1;
  var nrims = $('#iddv img').length;       // numar de imagini in #iddv

  // la clic pe #btn4
  $('#btn4').click(function(){
    // adauga bordura la al "ni-lea" imagine din #iddv
    $('#iddv img:nth-child('+ ni+ ')').css('border', '2px dashed blue');
    ni++;        // mareste "ni" cu 1

    // sterge evenimentul "click" de la #btn4 daca "ni" e mai mare decat numar imagini
    if(ni > nrims) $("#btn4").unbind('click');
  });
});
--></script>

Demo (clic de cateva ori pe buton):
Cerc Romb Triunghi

jQuery("parinte > copil")

Selectorul $("parinte > copil") selecteaza elementele "copil" aflate direct in elementele "parinte".

Exemplu, la clic pe un buton, adauga un chenar in jurul listelor care sunt copii directi in <ul class="clsul">.
<ul class="clsul">
 <li>Item 1</li>
 <li>Item 2, cu UL inclus
  <ul><li>Item inclus 1</li><li>Item inclus 2</li></ul>
 </li>
 <li>Item 3</li>
</ul><button id="btn5">Click</button>

<script type="text/javascript"><!--
$(document).ready(function() {
  // la clic pe #btn5
  $('#btn5').click(function(){
    $('ul.clsul > li').css('border', '1px solid #fe0001');
  });
});
--></script>

Demo:


• Observati diferenta dintre aceste doua selectoare: "parinte > copil" si "parinte copil" (fara '>' ).
Selectorul "P > C" seleceaza doar elementele copil directe, dar "P C" selecteaza toate elementele copil, cuprinzand si pe cele incluse de rang 2, 3 ...
- Iata acelasi exemplu prezentat mai sus, dar cu "P C" (fara '>' ). Chenarul va fi adaugat si la listele care sunt incluse in al doilea UL.
<ul class="clsul">
 <li>Item 1</li>
 <li>Item 2, cu UL inclus
  <ul><li>Item inclus 1</li><li>Item inclus 2</li></ul>
 </li>
 <li>Item 3</li>
</ul><button id="btn6">Click</button>

<script type="text/javascript"><!--
$(document).ready(function() {
  // la clic pe #btn6
  $('#btn6').click(function(){
    $('ul.clsul li').css('border', '1px solid #fe0001');
  });
});
--></script>

Demo:

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.
jQuery parent children si nth-child

Last accessed pages

  1. Curs si Tutoriale JavaScript (70094)
  2. Articolul din limba engleza - The article (41275)
  3. Creare aceeasi inaltime la elemente HTML (127)
  4. Trecutul simplu - Exercitii si teste incepatori (13482)
  5. Creare ceas cu data si ora (248)

Popular pages this month

  1. Cursuri si Tutoriale: Engleza, Spaniola, HTML, CSS, Php-Mysql, JavaScript, Ajax (5365)
  2. Curs HTML gratuit Tutoriale HTML5 (4411)
  3. Curs si Tutoriale JavaScript (3776)
  4. Curs PHP MySQL, Tutoriale si Scripturi PHP (3698)
  5. Curs CSS Online Tutoriale CSS3 (3651)