Lucru cu atribute HTML in PHP

hasAttribute
setAttribute
removeAttribute

Clasa PHP DOMElement contine metode care pot fi utilizate pentru: citire, setare si stergere atribute in documentul HTML incarcat in obiect DOMDocument.

Pentru a traversa un obiect PHP, se foloseste instructiunea foreach().

getAttribute

Functia getAttribute('attr') returneaza valoarea atributului specificat, sau un sir gol daca atributul "attr" nu e gasit.
- Aceasta metoda poate fi aplicata la un element HTML (sau XML) dintr-un obiect DOMDocument.
    - Se poate utiliza functia getElementsByTagName('tag') pt a prelua toate elementele cu un anumit <tag>.
    - Ca sa preluati elementul cu un anumit ID, se foloseste metoda getElementById('ID').

Exemplu, obtine valoarea "href" din fiecare <a> din #menu:
<?php
// sir cu continut HTML
$strhtml = '<!doctype html>
<html>
<head>
 <meta charset="utf-8" />
 <title>PHP getAttribute</title>
</head>
<body>
 <ul id="menu">
 <li><a href="http://www.coursesweb.net/" title="Cursuri programare web">CoursesWeb.net</a></li>
 <li><a href="http://www.marplo.net/" title="Cursuri gratuite Jocuri Anime">MarPlo.net</a></li>
 <li><a href="http://www.php.net/" title="PHP Website">php.net</a></li>
 </ul>
</body></html>';

// creaza obiectul DOMDocument si incarca HTML din sir
$dochtml = new DOMDocument();
$dochtml->loadHTML($strhtml);

// preia elementul cu id="menu"
$menu = $dochtml->getElementById('menu');

// obtine toate tag-urile <a> din $menu
$atgs = $menu->getElementsByTagName('a');

// parcurge obiectul cu toate <a> in $menu
foreach($atgs as $atag) {
  // afiseaza valoarea "href"
  echo $atag->getAttribute('href'). '<br/>';
}
?>

Rezultat:
http://www.coursesweb.net/
http://www.marplo.net/
http://www.php.net/

hasAttribute

Functia hasAttribute('attr') returneaza TRUE daca atributul transmis exista, altfel FALSE.
- Aceasta metoda e utila cand se doreste preluarea valorii unui anumit atribut, pentru a evita erorile, verifica daca acel atribut exista.
- Se poate folosi /incarca si doar o parte din documentul HTML.

Exemplu. Incarca un sir ce contine doar sectiunea BODY, afiseaza ID-ul si continutul DIV-urilor care au un atribut ID:
<?php
// sir cu continut HTML
$strhtml = '<body>
 <div id="dv1">Curs gratuit PHP-MySQL.</div>
 <div>Lucru cu atribute HTML in PHP.</div>
 <div id="did">Resurse Web Development.</div>
</body>';

// creaza obiectul DOMDocument si incarca HTML din sir
$dochtml = new DOMDocument();
$dochtml->loadHTML($strhtml);

// obtine toate tag-urile DIV
$divs = $dochtml->getElementsByTagName('div');

// parcurge obiectul cu toate DIV-urile
foreach($divs as $div) {
  // daca $div are ID, obtine si afiseaza ID-ul si continutul
  if($div->hasAttribute('id')) {
    $id = $div->getAttribute('id');
    $cnt = $div->nodeValue;

    echo $id. ' - '. $cnt. '<br/>';
  }
}
?>

Rezultat:
dv1 - Curs gratuit PHP-MySQL.
did - Resurse Web Development.

setAttribute

Functia setAttribute('attr', 'value') seteaza valoarea "value" la atributul "attr". Daca atributul nu exista, il creaza.
- Aceasta metoda e utila cand doriti sa creati un atribut intr-un tag, sau sa dati alta valoare atributului respectiv.
    - Cu metoda $doc->saveHTML() se poate adauga intr-un sir continutul dintr-un nod DOMDocument cu HTML. De obicei e necesara dupa efectuarea anumitor modificari in obiectul DOMDocument.
    - Acest cod:
$dochtml->getElementsByTagName('body')->item(0)
returneaza un nod DOMDocument cu elementul <body>. Este util daca doriti sa lucrati doar cu elementul <body> (incluzand tot continutul din el), de exemplu pt a salva intr-un sir continutul BODY.

Exemplu, seteaza class="newcls" la toate paragrafele (<p>):
<?php
$strhtml = '<!doctype html>
<html>
<head>
 <meta charset="utf-8" />
 <title>PHP setAttribute</title>
</head>
<body>
 <p class="cls">Lectii gratuite PHP-MySQL.</p>
 <p>URL: http://www.coursesweb.net/php-mysql/</p>
 <p>Resurse Web Development.</p>
</body></html>';

// creaza obiectul DOMDocument si incarca HTML din sir
$dochtml = new DOMDocument();
$dochtml->loadHTML($strhtml);

// obtine toate tag-urile <p>
$prgs = $dochtml->getElementsByTagName('p');

// parcurge obiectul cu toate paragrafele
foreach($prgs as $prg) {
  // seteaza /creaza class="newcls" la fiecare <p>
  $prg->setAttribute('class', 'newcls');
}

// obtine obiect cu elementul <body> (cu tot continutul din el)
$body = $dochtml->getElementsByTagName('body')->item(0);

// adauga continutul $body intr-un sir si-l afiseaza
$strbody = $dochtml->saveHTML($body);
echo $strbody;
?>

Rezultat:
<body>
 <p class="newcls">Lectii gratuite PHP-MySQL.</p>
 <p class="newcls">URL: http://www.coursesweb.net/php-mysql/</p>
 <p class="newcls">Resurse Web Development.</p>
</body>

removeAttribute

Functia removeAttribute('attr') sterge atributul "attr" din element. Returneaza TRUE la succes, sau FALSE in caz de esec.
Exemplu, sterge atributul "class" din fiecare tag <p> cu class="cls":
<?php
// sir cu continut HTML
$strhtml = '<body>
 <p class="cls">Lectii gratuite PHP-MySQL.</p>
 <p class="othercls">Cursuri programare web.</p>
</body>';

// creaza obiectul DOMDocument si incarca HTML din sir
$dochtml = new DOMDocument();
$dochtml->loadHTML($strhtml);

// obtine toate tag-urile <p>
$prgs = $dochtml->getElementsByTagName('p');

// parcurge obiectul cu toate paragrafele
foreach($prgs as $prg) {
  // daca elementul curent are class="cls", sterge atributul
  if($prg->hasAttribute('class') && $prg->getAttribute('class') == 'cls') {
    $prg->removeAttribute('class');
  }
}

// obtine obiect cu elementul <body> (cu tot continutul din el)
$body = $dochtml->getElementsByTagName('body')->item(0);

// adauga continutul $body intr-un sir si-l afiseaza
$strbody = $dochtml->saveHTML($body);
echo $strbody;
?>

Rezulta:
<body>
 <p>Lectii gratuite PHP-MySQL.</p>
 <p class="othercls">Cursuri programare web.</p>
</body>

getElementById si getElementsByTagName <<-- Anterior --- Urmator -->> Documente XML si utilizare

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 = array(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.
Lucru cu atribute HTML in PHP - Tutorial PHP