{% else-1 %}
Первая в жизни пагинация.
Юзать так:
$Pagination = new Pagination("SELECT * FROM `news`", $_GET['page']);
$query = $db->query("SELECT * FROM `news` LIMIT $Pagination->start, $Pagination->end"*;
while($news = $query->fetch_assoc()){
echo $news['content'];
}
$Pagination->out('/news');

Где $_GET['page'] - номер текущей страницы.

                        
<?php
/**
* Pagination class
*/
class Pagination
{
public $total;
public $start;
public $end;
public $page;

function __construct($sql, $page, $max = 10)
{
global $db;

if(empty($page)) $page = 1;
$this->page = $page;
$this->total = $db->query($sql)->num_rows;
$this->pages = ceil($this->total / $max);
$this->start = $page * $max - 10;
if($page == 1) $this->start = 0;
$this->end = $start + $max;
}

function out($self)
{
$out .= 'Стр. ';

if ($this->page != 1) {
$out .= '<a href="' . $self . '/page1"><<</a> ';
$out .= '<a href="' . $self . '/page' . ($this->page - 1) . '"><</a> ';
}

if (($this->page - 2) > 0) {
$out .= '<a href="' . $self .'/page'. ($this->page - 2) .'">'. ($this->page - 2) .'</a>';
$out .= ' | ';
}

if (($this->page - 1) > 0) {
$out .= '<a href="' . $self .'/page'. ($this->page - 1) .'">'. ($this->page - 1) .'</a>';
$out .= ' | ';
}

$out .= $this->page;

if (($this->page + 1) <= $this->pages) {
$out .= ' | ';
$out .= '<a href="' . $self . '/page' . ($this->page + 1) .'">' . ($this->page + 1) . '</a>';
}

if($this->page + 2 <= $this->pages) {
$out .= ' | ';
$out .= '<a href="' . $self . '/page' . ($this->page + 2) .'">' . ($this->page + 2) . '</a>';
}

if ($this->page != $this->pages) {
$out .= ' <a href="' . $self . '/page' . ($this->page + 1) . '">></a>';
$out .= ' <a href="'.$self.'/page' . $this->pages .'">>></a>';
}

echo '<div class="lst">'.$out.'</div>';
}
}
?>
0 80 0
0

Нет фото
KekuS * 0.04
• 20 май 2017, 20:59


Кидорас, thx bro =)

0

Нет фото
• 12 авг 2016, 01:46


$this->start = $page * $max - 10;
замени на
$this->start = $page * $max - $max;