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'>&lt;&lt;</a> &nbsp; ";  
  // obtine nr. pagina din urma 
  $prevpage = $currentpage - 1;  
  // arata < pt. link la o pagina in urma 
  echo " <a href='{$_SERVER['PHP_SELF']}?currentpage=$prevpage'>&lt;</a> &nbsp;";  
} 
 
// 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 "&nbsp; <a href='{$_SERVER['PHP_SELF']}?currentpage=$nextpage'>&gt;</a> ";  
  //  arata >> pt. ultima pagina
  echo " &nbsp; <a href='{$_SERVER['PHP_SELF']}?currentpage=$totalpages'>&gt;&gt;</a> ";  
}
?>

Daca doriti sa testati acest script, puteti folosi codul de mai jos pentru crearea tabelului MySQL, in plus, acesta adauga si cateva linii in tabel.
Copiati codul urmator intr-un fisier '.php' si apelati-l din browser (prin server).
Dupa ce ati creat tabelul si datele din el, apelati primul script, de paginare. Daca nu aveti erori, acesta va afisa paginat datele din tabel.

- Creare tabel MySQL
<?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(); 
?>

Un Test simplu in fiecare zi

HTML
CSS
JavaScript
PHP-MySQL
Engleza
Spaniola
Care tag HTML5 adauga o aplicatie externa (SWF, PDF) in pagina web?
<mark> <embed> <canvas>
<embed src="flash_game.swf" width="450" height="350" />
Ce pseudo-element adauga un anume stil la prima linie de text din element?
:first-letter :before :first-line
#id:first-line {
  font-weight: bold;
  color: blue;
}
Clic pe proprietatea obiectului window care preia sau seteaza adresa URL a paginii curente.
window.location window.self window.status
var url = window.location;
alert(url);
Indicati functia PHP care preia continutul unui fisier sau pagina si-l adauga intr-un sir.
fopen() file_put_contents() file_get_contents()
$homepage = file_get_contents("http://www.marplo.net/");
echo $homepage;
Care din urmatoarele perechi de numere sunt in ordine unul dupa altu?
seven - eight ten - six three - five
This fruit has seven or eight seeds.
- Acest fruct are sapte sau opt seminte.
Care din urmatoarele perechi de numere sunt in ordine unul dupa altu?
diez - seis siete - ocho tres - cinco
Esta fruta tiene siete u ocho semillas.
- Acest fruct are sapte sau opt seminte.
Script paginare

Last accessed pages

  1. Definire si Utilizare Functii in JS (1938)
  2. Cursuri si Tutoriale: Engleza, Spaniola, HTML, CSS, Php-Mysql, JavaScript, Ajax (118307)
  3. De răstignit, mă pot răstigni numai pe mine (7)
  4. Curs PHP MySQL, Tutoriale si Scripturi PHP (46375)
  5. Curs si Tutoriale JavaScript (48809)

Popular pages this month

  1. Cursuri si Tutoriale: Engleza, Spaniola, HTML, CSS, Php-Mysql, JavaScript, Ajax (1356)
  2. Curs HTML gratuit Tutoriale HTML5 (942)
  3. Curs si Tutoriale JavaScript (869)
  4. Curs si Tutoriale Ajax (847)
  5. Curs CSS Online Tutoriale CSS3 (814)