Создать ответ 
 
Рейтинг темы:
  • Голосов: 12 - Средняя оценка: 1.33
  • 1
  • 2
  • 3
  • 4
  • 5
пагинатор
Автор Сообщение
ролрол Не на форуме
Junior Member
**

Сообщений: 6
Зарегистрирован: 27-10-2013
Рейтинг: 0
Сообщение: #1
пагинатор
Здраствуйте. Помогите переделать скрипт пагинатора. У меня записи в бд идут по ид 1 2 3 4 5 и тд он их выводит по этому порядку, а мне надо наоборот 5 4 3 2 1.
Код:
<?php
    include('connect.php');    
    $tableName="index";        
    $targetpage = "index.php";     
    $limit = 1;
    
    $query = "SELECT COUNT(*) as num FROM $tableName";
    $total_pages = mysql_fetch_array(mysql_query($query));
    $total_pages = $total_pages[num];

    
    $stages = 3;
    $page = mysql_escape_string($_GET['page']);
    if($page){
        $start = ($page - 1) * $limit;
        
    }else{
        $start = 0;    
        }    
    
    // Get page data
    $query1 = "SELECT * FROM $tableName LIMIT $start, $limit";
    
    $result = mysql_query($query1);
    

    // Initial page num setup
    if ($page == 0){$page = 1;}
    $prev = $page - 1;    
    $next = $page + 1;                            
    $lastpage = ceil($total_pages/$limit);        
    $LastPagem1 = $lastpage - 1;                    
    
    
    $paginate = '';
    if($lastpage > 1)
    {    
    

    
    
        $paginate .= "<div class='paginate'>";
        // Previous
        if ($page > 1){
            $paginate.= "<a href='$targetpage?page=$prev'>Предыдущая</a>";
        }else{
            $paginate.= "<span class='disabled'>Предыдущая</span>";    }
            

        
        // Pages    
        if ($lastpage < 7 + ($stages * 2))    // Not enough pages to breaking it up
        {    
            for ($counter = 1; $counter <= $lastpage; $counter++)
            {
                if ($counter == $page){
                    $paginate.= "<span class='current'>$counter</span>";
                }else{
                    $paginate.= "<a href='$targetpage?page=$counter'>$counter</a>";}                    
            }
        }
        elseif($lastpage > 5 + ($stages * 2))    // Enough pages to hide a few?
        {
            // Beginning only hide later pages
            if($page < 1 + ($stages * 2))        
            {
                for ($counter = 1; $counter < 4 + ($stages * 2); $counter++)
                {
                    if ($counter == $page){
                        $paginate.= "<span class='current'>$counter</span>";
                    }else{
                        $paginate.= "<a href='$targetpage?page=$counter'>$counter</a>";}                    
                }
                $paginate.= "...";
                $paginate.= "<a href='$targetpage?page=$LastPagem1'>$LastPagem1</a>";
                $paginate.= "<a href='$targetpage?page=$lastpage'>$lastpage</a>";        
            }
            // Middle hide some front and some back
            elseif($lastpage - ($stages * 2) > $page && $page > ($stages * 2))
            {
                $paginate.= "<a href='$targetpage?page=1'>1</a>";
                $paginate.= "<a href='$targetpage?page=2'>2</a>";
                $paginate.= "...";
                for ($counter = $page - $stages; $counter <= $page + $stages; $counter++)
                {
                    if ($counter == $page){
                        $paginate.= "<span class='current'>$counter</span>";
                    }else{
                        $paginate.= "<a href='$targetpage?page=$counter'>$counter</a>";}                    
                }
                $paginate.= "...";
                $paginate.= "<a href='$targetpage?page=$LastPagem1'>$LastPagem1</a>";
                $paginate.= "<a href='$targetpage?page=$lastpage'>$lastpage</a>";        
            }
            // End only hide early pages
            else
            {
                $paginate.= "<a href='$targetpage?page=1'>1</a>";
                $paginate.= "<a href='$targetpage?page=2'>2</a>";
                $paginate.= "...";
                for ($counter = $lastpage - (2 + ($stages * 2)); $counter <= $lastpage; $counter++)
                {
                    if ($counter == $page){
                        $paginate.= "<span class='current'>$counter</span>";
                    }else{
                        $paginate.= "<a href='$targetpage?page=$counter'>$counter</a>";}                    
                }
            }
        }
                    
                // Next
        if ($page < $counter - 1){
            $paginate.= "<a href='$targetpage?page=$next'>Следующая</a>";
        }else{
            $paginate.= "<span class='disabled'>Следующая</span>";
            }
            
        $paginate.= "</div>";        
    
    
}

// pagination

?>

<ul>

<?php


        while($row = mysql_fetch_array($result))
        {
        
        echo '<li>'.$row['printable_name'].'</li>';
        
        }
    
?>
</ul>
<table width= "100%" class= "zxcv"><tr><td><?php  echo $paginate; ?>    </td></tr></table>
05-11-2013 18:52
Найти все сообщения Цитировать это сообщение
Создать ответ 


Сообщения в этой теме
пагинатор - ролрол - 05-11-2013 18:52
RE: пагинатор - Kolyan - 06-11-2013, 11:43
RE: пагинатор - ролрол - 06-11-2013, 15:04



Пользователи просматривают эту тему: 1 Гость(ей)
Обратная связьSitesCo.ruВернуться к началуВернуться к содержимомуЛёгкий режимСписок RSS