O versiune mai noua, bazata pe clase si obiecte, e la pagina: Clasa Paginare - Script PHP
In aceasta pagina este prezentat un model de script pentru paginarea datelor dintr-un tabel MySQL.
- Puteti copia codul scriptului direct din pagina (codul de mai jos), sau puteti descarca arhiva din link-ul "Download" de mai sus, aceasta contine fisierele '.php' pentru crearea tabelului si paginare.
In general, scripturile de paginare pe care le gasiti, pentru a putea fi folosite trebuie adaptate de fiecare in functie de structura tabelul MySQL folosit si modul dorit de afisare a datelor.
Acest script este un exemplu din care puteti invata mecanismul de construire a unui script de paginare. Explicatiile necesare le gasiti in interiorul scriptului, unde sunt adaugate comentarii la fiecare pas, care va ajuta sa intelegeti logica scriptului si rolul liniilor de cod folosite.
Daca doriti sa folositi acest model pentru site-ul dv., trebuie sa modificati in primul rand datele de conectare la baza de date cu cele ale dv., apoi modificati numele tabelului (aici "nume_tb") cu cel pe care-l aveti iar la afisarea datelor schimbati numele coloanelor (aici 'id' si 'texte') cu cele din tabelul dv'.
In acest exemplu afisare datelor se face cat mai simplu. Daca aveti cat de cat cunostinte de PHP, puteti crea un mod de afisare propriu prin adaugarea de elemente HTML in codul scriptului, la instructiunea "echo" din interiorul instructiunii "for($i=0; $i<count($id); $i++)" care parcurge si afiseaza datele returnate din coloanele tabelului.
- Scriptul pentru paginare
<?php // Script de paginare, de la https://marplo.net // Datele pt. conectare la baza de date // MODIFICATI $host = "localhost"; // server MySQL $utilizator = "root"; $parola = "parola"; $numebd = "nume_bd"; // nume baza de date // Conectarea la baza de date $conn = mysql_connect($host, $utilizator, $parola); if (!$conn) { echo 'Conectare nereusita la MySQL'; exit; } // Selectarea bazei de date if (!mysql_select_db($numebd, $conn)) { echo 'Baza de date nu a putut fi selectata deoarece : '. mysql_error(); exit; } // Setarea pentru format UTF-8 $sql = "SET NAMES 'utf8'"; mysql_query($sql, $conn); // Afla cate linii sunt in tabel (MODIFICATI 'nume_tb') din baza de date $sql = "SELECT COUNT(*) FROM `nume_tb`"; $result = mysql_query($sql, $conn) or trigger_error(E_USER_ERROR); $r = mysql_fetch_row($result); $numrows = $r[0]; // Stabileste numarul de linii din tabel afisate in pagina $rowsperpage = 10; // afla numarul total necesar de pagini $totalpages = ceil($numrows / $rowsperpage); // ceil face rotunjire la int. maxim // Obtine pagina curenta sau seteaza default if (isset($_GET['currentpage']) && is_numeric($_GET['currentpage'])) { // seteaza variabila ca int $currentpage = (int) $_GET['currentpage']; } else { // pagina care este initial afisata (pagina default) $currentpage = 1; } // daca pagina curenta e mai mare decat total pagini... if ($currentpage > $totalpages) { // seteaza pagina curenta la ultima pagina $currentpage = $totalpages; } // daca pagina curenta e mai mica decat prima pagina... if ($currentpage < 1) { // seteaza pagina curenta la prima pagina $currentpage = 1; } // lista cu pagini, in functie de pagina curenta $offset = ($currentpage - 1) * $rowsperpage; // obtine datele din tabel (MODIFICATI 'nume_tb') din baza de date $sql = "SELECT * FROM `nume_tb` LIMIT $offset, $rowsperpage"; $result = mysql_query($sql, $conn) or trigger_error(E_USER_ERROR); // parcurgerea matricei cu datele obtinute while ($list = mysql_fetch_assoc($result)) { // - MODIFICATI numele coloanelor tabelului ('id' si 'texte') // Stocheaza datele returnate de MySQL in variabile array pt. fiecare coloana $id[] = $list['id']; $text[] = $list['texte']; } mysql_close(); // Incheie conexiunea cu mysql /*** Afisarea datelor obtinute ***/ // Parcurge variabilele array setate in bucla WHILE for($i=0; $i<count($id); $i++) { // Aici puteti adauga cod HTML pentru aspectul grafic al afisarii echo $id[$i]. " - ". $text[$i]. "<br />"; } /*** Construirea link-urilor pt. paginare ***/ // raza nr. link-uri din jurul celui curent $range = 3; // Link-uri inapoi, daca pagina curenta nu e prima if ($currentpage > 1) { // arata << pt. link la prima pagina echo " <a href='{$_SERVER['PHP_SELF']}?currentpage=1'><<</a> "; // obtine nr. pagina din urma $prevpage = $currentpage - 1; // arata < pt. link la o pagina in urma echo " <a href='{$_SERVER['PHP_SELF']}?currentpage=$prevpage'><</a> "; } // definirea link-urilor din raza paginii curente for ($x = ($currentpage - $range); $x < (($currentpage + $range) + 1); $x++) { // daca e un nr. de pagina valid ... if (($x > 0) && ($x <= $totalpages)) { // daca nr. e pagina curenta ... if ($x == $currentpage) { // afiseaza nr. pagina fara a fi link echo " [<b>$x</b>] "; // daca nr. nu e pagina curenta ... } else { // il face link echo " <a href='{$_SERVER['PHP_SELF']}?currentpage=$x'>$x</a> "; } } } // Daca pagina curenta nu e ultima, afiseaza link inainte si spre ultima pagina if ($currentpage != $totalpages) { // obtine pagina urmatoare $nextpage = $currentpage + 1; // arata > pt. urmatoarea pagina echo " <a href='{$_SERVER['PHP_SELF']}?currentpage=$nextpage'>></a> "; // arata >> pt. ultima pagina echo " <a href='{$_SERVER['PHP_SELF']}?currentpage=$totalpages'>>></a> "; } ?>
<?php // Datele pt. conectare la baza de date // MODIFICATI $host = "localhost"; // server MySQL $utilizator = "root"; $parola = "parola"; $numebd = "nume_bd"; // nume baza de date // Conectarea la baza de date $conn = mysql_connect($host, $utilizator, $parola); if (!$conn) { echo 'Conectare nereusita la MySQL'; exit; } // Selectarea bazei de date if (!mysql_select_db($numebd, $conn)) { echo 'Baza de date nu a putut fi selectata deoarece: '. mysql_error(); exit; } // Setarea pentru format UTF-8 $sql = "SET NAMES 'utf8'"; mysql_query($sql, $conn); // Creaza tabelul 'nume_tb' cu 2 coloane "id' si 'texte' $sql = "CREATE TABLE `nume_tb` ( `id` int(11) NOT NULL auto_increment, `texte` varchar(250) NOT NULL default '', PRIMARY KEY (`id`))"; $tabel = mysql_query($sql); if ($tabel) echo 'Tabelul comentarii a fost creat'; else echo 'Tabelul nu a putut fi creat deoarece - '. mysql_error(); // Adaugare date in tabel $sql = "INSERT INTO `nume_tb` (id, texte) VALUES (1, 'Script paginare, linia 1'), (2, 'Script paginare, linia 2'), (3, 'Script paginare, linia 3'), (4, 'Script paginare, linia 4'), (5, 'Script paginare, linia 5'), (6, 'Script paginare, linia 6'), (7, 'Script paginare, linia 7'), (8, 'Script paginare, linia 8'), (9, 'Script paginare, linia 9'), (10, 'Script paginare, linia 10'), (11, 'Script paginare, linia 11'), (12, 'Script paginare, linia 12'), (13, 'Script paginare, linia 13'), (14, 'Script paginare, linia 14'), (15, 'Script paginare, linia 15')"; if (!mysql_query($sql, $conn)) { print '<br>Eroare la introducerea datelor: '. mysql_error(); } mysql_close(); ?>
<ul> <li>http://coursesweb.net/html/</li> <li>http://www.marplo.net/html/</li> </ul>
.some_class { display: list-item; }
var obj = { "courses": ["php", "javascript", "ajax"] }; var jsonstr = JSON.stringify(obj); alert(jsonstr); // {"courses":["php","javascript","ajax"]}
$strhtml = '<body><div id="dv1">CoursesWeb.net</div></body>'; $dochtml = new DOMDocument(); $dochtml->loadHTML($strhtml); $elm = $dochtml->getElementById("dv1"); echo $elm->nodeValue; // CoursesWeb.net
I`m living here. - Traiesc /Locuiesc aici.
Estoy viviendo aquĆ. - Traiesc /Locuiesc aici.