ФорумПрограммированиеПыхнуть хотите?F.A.Q. → Постраничный вывод информации из БД (пагинатор)

Постраничный вывод информации из БД (пагинатор)

  • md5

    Сообщения: 11960 Репутация: N Группа: в ухо

    Spritz 19 января 2010 г. 16:11, спустя 4 минуты 34 секунды



    adw0rd, первую страницу открой, это мой фак по пагинатору…
    ты в посте шрифты бы подправил…
    а ты бы свои статьи посмотрел и на их шрифты, не в статьях дело, парсер-лох)
    Спустя 31 сек.
    а вобще, с оформление все хорошо — читайте http://pyha.ru/articles/php/paginator/
    все умрут, а я изумруд
  • Trej Gun

    Сообщения: 5305 Репутация: N Группа: в ухо

    Spritz 19 января 2010 г. 16:14, спустя 3 минуты 6 секунд

    вы не уравновешенный "молодой человек"

    это ты самому доброму и уровновешеному из нас сказал


    а вообще у вас тут хорошо, особая такая атмосфера.

    это наша изюминка

    тут люди со стойкой жизненой позицией

    другие сами сваливают

    парсер-лох

    непизди а поправь настройки, я его прикрутил теперь хоть весь код подсвечиваеться почеловечески
  • md5

    Сообщения: 11960 Репутация: N Группа: в ухо

    Spritz 19 января 2010 г. 16:17, спустя 3 минуты 7 секунд

    CTAPbIu_MABP, шрифты пиздецки огромные)
    если знаешь где - поправь, плиз
    я заебусь искать
    все умрут, а я изумруд
  • Trej Gun

    Сообщения: 5305 Репутация: N Группа: в ухо

    Spritz 19 января 2010 г. 16:30, спустя 13 минут

    md5, вечером в скайп напомни
    мне надо новые имена на свн
  • adw0rd

    Сообщения: 22959 Репутация: N Группа: в ухо

    Spritz 19 января 2010 г. 16:30, спустя 31 секунду

    а ты бы свои статьи посмотрел и на их шрифты
    ну у меня не такие популярные ;)
    Спустя 20 сек.
    тикеты рулят
    https://smappi.org/ - платформа по созданию API на все случаи жизни
  • berikiushi

    Сообщения: 4 Репутация: N Группа: Кто попало

    Spritz 19 января 2010 г. 16:32, спустя 2 минуты



    for ($i=$right_neighbour; $i>=$left_neighbour; $i–)
    {
           if ($i != $page)
           {
                   print ' <a href="?page=' . $i . '">' . $i . '</a> ';
           }
           else
           {
                   // выбранная страница
                   print ' <b>' . $i . '</b> ';
           }
    }


    спасибо но md5 написал тоже самое раньше) и короче)


    md5, я думал он говорит о своем коде, который он потом удалил…. :(
    вот какое зло от удаления постов

    Да нафигаж я б стал говорить о коде, который удалил :) то что удалил я сам поторопился и выложил, потом мне ткнули на пару причин и я удалил разобравшись, потому что некоторые так посоветовали) ну я и удали, дурак старый)

    md5
    вывод цыферок реверснулся, но надо еще поменять в отображении местами ← вперед назад → ..эт я так, вдруг кто не догадается)
  • md5

    Сообщения: 11960 Репутация: N Группа: в ухо

    Spritz 19 января 2010 г. 16:38, спустя 5 минут 28 секунд

    berikiushi, ну, если не догадается - прийдет сюда и спросит)
    все умрут, а я изумруд
  • phpdude

    Сообщения: 26646 Репутация: N Группа: в ухо

    Spritz 19 января 2010 г. 16:54, спустя 15 минут 58 секунд

    berikiushi, ох ебать, чувак я те сочуствую.

    http://factorial.ru/ - твой провайдер? такая неебическая компания из советских времен, я ебал ..
    Сапожник без сапог
  • berikiushi

    Сообщения: 4 Репутация: N Группа: Кто попало

    Spritz 19 января 2010 г. 17:45, спустя 51 минуту 42 секунды

    вы что из челябинска?
  • md5

    Сообщения: 11960 Репутация: N Группа: в ухо

    Spritz 19 января 2010 г. 17:47, спустя 1 минуту 27 секунд

    я из краснодара и мне похуй =)
    все умрут, а я изумруд
  • adw0rd

    Сообщения: 22959 Репутация: N Группа: в ухо

    Spritz 19 января 2010 г. 17:48, спустя 1 минуту 23 секунды

    челябинск… краснодар… НАШАРАША прям…
    https://smappi.org/ - платформа по созданию API на все случаи жизни
  • Ewg777

    Сообщения: 510 Репутация: N Группа: Джедаи

    Spritz 19 января 2010 г. 18:10, спустя 21 минуту 28 секунд

    Таганрог
    Спустя 170 сек.
    На пыхе Сообщений — 77759.
    Даёшь 77777
  • Troy

    Сообщения: 2532 Репутация: N Группа: Джедаи

    Spritz 20 января 2010 г. 8:13, спустя 14 часов 2 минуты 52 секунды

    phpdude, ты про ЮТЫКУ не знаеш
  • buykz

    Сообщения: 1 Репутация: N Группа: Кто попало

    Spritz 27 февраля 2010 г. 15:21, спустя 38 дней 7 часов 8 минут

    спасибо тебе md5, очень просто и понятно
  • IceD

    Сообщения: 9 Репутация: N Группа: Кто попало

    Spritz 1 марта 2010 г. 7:19, спустя 1 день 15 часов 58 минут

    я на своих проектах пользуюсь следующим классом пагинации:


    <?php
    class Pagination {

    var $base_url = ''; //ссылка по которой строим пагинацию
    var $total_rows = ''; //количество ссылок которые нам нужны
    var $per_page = 10; // сколько у нас на странице
    var $num_links = 2; // количество выводимых ссылок
    var $cur_page = 0;

    var $first_link = '&lsaquo; First'; //стиль первой ссылки
    var $next_link = '>'; //стиль следующей ссылки
    var $prev_link = '<'; //стиль предыдущей ссылки
    var $last_link = 'Last &rsaquo;'; //стиль последней ссылки

    //Обертки вокруг ссылок пагинации - чтобы было например <ul><li>первая ссылка</li> <li>2</li><li>3</li><li>последняя ссылка</li></ul>
    var $full_tag_open = ''; //обертка вокруг всех ссылок - тот самый <ul>
    var $full_tag_close = '';

    var $first_tag_open = ''; //первая страница
    var $first_tag_close = '&nbsp;';

    var $last_tag_open = '&nbsp;'; //последняя страница
    var $last_tag_close = '';

    var $cur_tag_open = '&nbsp;<b>'; //текущая страница
    var $cur_tag_close = '</b>';

    var $next_tag_open = '&nbsp;'; //следующая страница
    var $next_tag_close = '&nbsp;';

    var $prev_tag_open = '&nbsp;'; //предыдущая страница
    var $prev_tag_close = '';

    var $num_tag_open = '&nbsp;'; //цыферы
    var $num_tag_close = '';


    /**
    * Constructor
    *
    * @param array initialization parameters
    */

    function Pagination($params = array())
    {
    if (count($params) > 0)
    {
    $this->initialize($params);
    }

    }

    // ——————————————————————–

    /**
    * Initialize
    *
    * @param array initialization parameters
    * @return void
    */
    function initialize($params = array())
    {
    if (count($params) > 0)
    {
    foreach ($params as $key => $val)
    {
    if (isset($this->$key))
    {
    $this->$key = $val;
    }
    }
    }
    }

    // ——————————————————————–

    /**
    * Generate the pagination links
    *
    * @return string
    */
    function create_links()
    {
    // If our item count or per-page total is zero there is no need to continue.
    if ($this->total_rows == 0 OR $this->per_page == 0)
    {
    return '';
    }

    // Calculate the total number of pages
    $num_pages = ceil($this->total_rows / $this->per_page);

    // Is there only one page? Hm… nothing more to do here then.
    if ($num_pages == 1)
    {
    return '';
    }

    // Determine the current page number.
    $page = isset($_GET['page']);
    if ($page != 0)
    {
    $page = $_GET['page'];
    $this->cur_page = $page;

    // Prep the current page - no funny business!
    $this->cur_page = (int) $this->cur_page;
    }

    $this->num_links = (int)$this->num_links;

    if ($this->num_links < 1)
    {
    return 'Your number of links must be a positive number.';
    }

    if ( ! is_numeric($this->cur_page))
    {
    $this->cur_page = 0;
    }

    // Is the page number beyond the result range?
    // If so we show the last page
    if ($this->cur_page > $this->total_rows)
    {
    $this->cur_page = ($num_pages - 1) * $this->per_page;
    }

    $uri_page_number = $this->cur_page;
    $this->cur_page = floor(($this->cur_page/$this->per_page) + 1);

    // Calculate the start and end numbers. These determine
    // which number to start and end the digit links with
    $start = (($this->cur_page - $this->num_links) > 0) ? $this->cur_page - ($this->num_links - 1) : 1;
    $end = (($this->cur_page + $this->num_links) < $num_pages) ? $this->cur_page + $this->num_links : $num_pages;

    // Add a trailing slash to the base URL if needed
    $this->base_url = rtrim($this->base_url, '/') .'';

    // And here we go…
    $output = '';

    // Render the "First" link
    if ($this->cur_page > $this->num_links)
    {
    $output .= $this->first_tag_open.'<a href="'.$this->base_url.'">'.$this->first_link.'</a>'.$this->first_tag_close;
    }

    // Render the "previous" link
    if ($this->cur_page != 1)
    {
    $i = $uri_page_number - $this->per_page;
    if ($i == 0) $i = '';
    $output .= $this->prev_tag_open.'<a href="'.$this->base_url.$i.'">'.$this->prev_link.'</a>'.$this->prev_tag_close;
    }

    // Write the digit links
    for ($loop = $start -1; $loop <= $end; $loop++)
    {
    $i = ($loop * $this->per_page) - $this->per_page;

    if ($i >= 0)
    {
    if ($this->cur_page == $loop)
    {
    $output .= $this->cur_tag_open.$loop.$this->cur_tag_close; // Current page
    }
    else
    {
    $n = ($i == 0) ? '' : $i;
    $output .= $this->num_tag_open.'<a href="'.$this->base_url.$n.'">'.$loop.'</a>'.$this->num_tag_close;
    }
    }
    }

    // Render the "next" link
    if ($this->cur_page < $num_pages)
    {
    $output .= $this->next_tag_open.'<a href="'.$this->base_url.($this->cur_page * $this->per_page).'">'.$this->next_link.'</a>'.$this->next_tag_close;
    }

    // Render the "Last" link
    if (($this->cur_page + $this->num_links) < $num_pages)
    {
    $i = (($num_pages * $this->per_page) - $this->per_page);
    $output .= $this->last_tag_open.'<a href="'.$this->base_url.$i.'">'.$this->last_link.'</a>'.$this->last_tag_close;
    }

    // Kill double slashes. Note: Sometimes we can end up with a double slash
    // in the penultimate link so we'll kill all double slashes.
    $output = preg_replace("#([^:])//+#", "\\1/", $output);

    // Add the wrapper HTML if exists
    $output = $this->full_tag_open.$output.$this->full_tag_close;

    return $output;
    }
    }
    // END Pagination Class
    ?>


    пример использования - возьмем эту страницу.


    //конфигурация класса - можно конешно через сетторы (__set), но мне было удобнее массивом


    $config['base_url'] = 'http://pyha.ru/forum/topic/299.';
    $config['per_page'] = '15';
    $config['num_links'] = 4;
    $config['first_link'] = '&#171; В начало |';
    $config['last_link'] = '| В конец &#187;';
    $config['next_link'] = '>';
    $config['prev_link'] = '<';
    $config['full_tag_open'] = '<ul class="pagin">';
    $config['full_tag_close'] = '</ul>';
    $config['first_tag_open'] = '<li>';
    $config['first_tag_close'] = '</li>';
    $config['last_tag_open'] = '<li>';
    $config['last_tag_close'] = '</li>';
    $config['next_tag_open'] = '<li>';
    $config['next_tag_close'] = '</li>';
    $config['prev_tag_open'] = '<li>';
    $config['prev_tag_close'] = '</li>';
    $config['cur_tag_open'] = '<li class="active"><div>';
    $config['cur_tag_close'] = '</div></li>';
    $config['num_tag_open'] = '<li>';
    $config['num_tag_close'] = '</li>';


    $page = (empty($_GET['page']))? 0 : (int)$_GET['page'];

    $topics = $Tred->getTopics('299', $page); //массив топиков. Получаем на конкретно нужной странице

    $config['total_rows'] = $Tred->getCountTopics('299'); //всего допустим 74 топика,

    $pagination = new Pagination();

    $pagination->initialize($config);

    echo $pagination->create_links();

    foreach ($topics as $topic) {
    //вывод топика
    }




    или пример 2.

    // конфиг как в примере 1
    $page = (empty($_GET['page']))? 0 : (int)$_GET['page'];

    $topics = $Tred->getTopics('299'); //массив топиков. Получаем все топики.

    $config['total_rows'] = count($topics); //всего допустим 74 топика,

    $topics = array_slice($topics, $page, $config['per_page']); //обрезаем массив чтобы выводил столько сколько нужно

    $pagination = new Pagination();

    $pagination->initialize($config);

    echo $pagination->create_links();

    foreach ($topics as $topic) {
    //вывод топика
    }


    недостатки второго способа - при большом объеме массива он просто в памяти его будет держать.

Пожалуйста, авторизуйтесь, чтобы написать комментарий!