Показать сообщение отдельно

  #2  
Старый 07.12.2009, 07:10
b3
Постоянный
Регистрация: 05.12.2004
Сообщений: 647
Провел на форуме:
1698585

Репутация: 818


Отправить сообщение для b3 с помощью ICQ
По умолчанию

http://www.tigir.com/paging.htm
Вот навоял для ДЛЕ, выводит по 2 новости на страницу, точнее выводит только колонку short_story ибо у меня база ДЛЕ была пустая.

PHP код:
<?php
require('paging.inc.php');
$_DB = new mysqli('localhost','root','','dle');
$_PAGING = new Paging($_DB);
$_PAGING->set_page_size(2);

$r $_PAGING->get_page'SELECT * FROM dle_post' ); 
while(
$row $r->fetch_assoc())
{
echo 
$row['short_story'].'<br>';
}

echo 
$_PAGING->get_result_text().' объявлений<br>';
echo 
'Страницы: '.$_PAGING->get_prev_page_link().' '.$_PAGING->get_next_page_link().'<br /><br />';
echo 
$_PAGING->get_page_links();
?>
Вот сам класс:
PHP код:
<?php
class Paging {

private 
$page_size 10;
private 
$link_padding 10;
private 
$page_link_separator ' ';
private 
$next_page_text 'следующая →';
private 
$prev_page_text '← предыдущая';
private 
$result_text_pattern 'Показано с %s по %s из %s';
private 
$page_var 'p';

private 
$db;
private 
$q;
private 
$total_rows;
private 
$total_pages;
private 
$cur_page;

public function 
__construct($db$q=''$page_var='p')
{
    
$this->db $db;
    if (
$q$this->set_query($q);
    
$this->page_var $page_var;
    
$this->cur_page = isset($_GET[$this->page_var]) && (int)$_GET[$this->page_var] > ? (int)$_GET[$this->page_var] : 1;
}

public function 
set_query($q)
{
    
$this->$q;
}

public function 
set_page_size($page_size)
{
    
$this->page_size abs((int)$page_size);
}

public function 
set_link_padding($padding)
{
    
$this->link_padding abs((int)$padding);
}

public function 
get_page($q='')
{
    if (
$q$this->set_query($q);

    
$r $this->db->query$this->query_paging($this->q) );
    
$this->total_rows array_pop($this->db->query('SELECT FOUND_ROWS()')->fetch_row());

    if (
$this->page_size !== 0$this->total_pages ceil($this->total_rows/$this->page_size);
    
    if (
$this->cur_page $this->total_pages)
    {
        
$this->cur_page $this->total_pages;
        if ( 
$this->total_pages $r $this->db->query$this->query_paging($this->q) );
    }
    
    return 
$r;
}

public function 
get_result_text()
{
    
$start = (($this->cur_page-1) * $this->page_size)+1;
    
$end = (($start-1+$this->page_size) >= $this->total_rows)? $this->total_rows:($start-1+$this->page_size);

    return 
sprintf($this->result_text_pattern$start$end$this->total_rows);
}

public function 
get_page_links()
{
    if ( !isset(
$this->total_pages) ) return '';

    
$page_link_list = array();

    
$start $this->cur_page $this->link_padding;
    if ( 
$start $start 1;
    
$end $this->cur_page $this->link_padding-1;
    if ( 
$end $this->total_pages $end $this->total_pages;

    if ( 
$start )  $page_link_list[] = $this->get_page_link$start-1$start '...' '' );
    for (
$i=$start$i <= $end$i++)  $page_link_list[] = $this->get_page_link$i );
    if ( 
$end $this->total_pages $page_link_list[] = $this->get_page_link$end +1$end == $this->total_pages '' '...' );
    if ( 
$end <= $this->total_pages $page_link_list[] = $this->get_page_link$this->total_pages );

    return 
implode($this->page_link_separator$page_link_list);
}

public function 
get_next_page_link()
{
    return isset(
$this->total_pages) && $this->cur_page $this->total_pages $this->get_page_link$this->cur_page 1$this->next_page_text ) : '';
}

public function 
get_prev_page_link()
{
    return isset(
$this->total_pages) && $this->cur_page $this->get_page_link$this->cur_page 1$this->prev_page_text ) : '';
}

private function 
get_page_link($page$text='')
{
    if (!
$text)    $text $page;

    if (
$page != $this->cur_page)
    {
        
$reg '/((&|^)'.$this->page_var.'=)[^&#]*/';
        
$url '?'.( preg_match$reg$_SERVER['QUERY_STRING'] ) ? preg_replace($reg'${1}'.$page$_SERVER['QUERY_STRING']) : ( $_SERVER['QUERY_STRING'] ? $_SERVER['QUERY_STRING'].'&' '' ).$this->page_var.'='.$page);
        return 
'<a href="'.$url.'">'.$text.'</a>';
    }
    return 
'<span>'.$text.'</span>';
}

private function 
query_paging()
{
    
$q $this->q;

    if (
$this->page_size != 0)
    {
        
//calculate the starting row
        
$start = ($this->cur_page-1) * $this->page_size;
        
//insert SQL_CALC_FOUND_ROWS and add the LIMIT
        
$q preg_replace('/^SELECT\s+/i''SELECT SQL_CALC_FOUND_ROWS '$this->q)." LIMIT {$start},{$this->page_size}";
    }

    return 
$q;
}
}
?>
 
Ответить с цитированием