Пользовательская нумерация страниц в Cake PHP - PullRequest
4 голосов
/ 09 марта 2012

Я новичок в cakePHP, и я не хочу создавать пользовательскую нумерацию страниц в cakePHP.

функция $paginator->numbers() ; отображает номера страниц следующим образом:

1 | 2 | 3 | 4 | ...

просматривая параметры, есть несколько параметров, чтобы изменить разделитель, добавить класс стиля css .. и т. Д.

я хочу, чтобы моя нумерация страниц была такой:

1-20 21-40 41-60 61-80 ... >>

у кого-нибудь есть идея о том, как его кодировать?

РЕДАКТИРОВАТЬ:

Я создал пользовательский помощник для разбивки на страницы: app/View/Helper/,

и я добавил CustomPaginatorHelper к helpers моего Controller, например:

public $helpers = array('CustomPaginator', 'Html', 'Form', 'Js');

но я получил эту ошибку:

Fatal error: Class 'PaginatorHelper' not found in /Applications/MAMP/htdocs/QRCode/app/View/Helper/CustomPaginatorHelper.php on line 2

похоже, он не знает PaginatorHelper !!! Где я должен добавить свой кастом Paginator ??

NB: номера ваших функций () будут отображать только формат нумерации страниц: 1-20 21-40 ... и т. Д., Но без ссылок на страницы, я думаю:)

РЕДАКТИРОВАТЬ 2:

Я добавил App::set('PaginatorHelper','/View/Helper/'); и больше не вижу этой ошибки. Теперь я пытаюсь вызвать метод numbers() пользовательского пагинатора следующим образом:

$this->CustomPaginator->numbers(); 

но я получаю эту ошибку:

Fatal error: Call to a member function numbers() on a non-object in /Applications/MAMP/htdocs/QRCode/app/View/Codes/index.ctp on line 71

каков источник этой ошибки? я пытался добавить свой customPaginatorHelper в переменную $ helpers моего контроллера, но я все еще получаю ту же ошибку; есть идеи ?

заранее спасибо

Ответы [ 5 ]

4 голосов
/ 10 марта 2012

Ключевым моментом, который необходимо знать здесь, является наличие компонента пагинатора (используется в контроллере) и помощника по разбиению на страницы (используется в представлении). То, что вы используете, это класс PaginatorHelper, который обрабатывает рендеринг элементов, связанных с разбиением на страницы.

К сожалению, с PaginatorHelper нет способа сделать то, что вы хотите достичь. Наилучшим подходом, если вы хотите это сделать, было бы расширение класса PaginatorHelper и переопределение метода numbers() для возврата того, что вы хотите.

Я посмотрел на этот конкретный метод, и, к сожалению, он не очень хорош - он длиной более 100 строк! Тем не менее, я создал класс, который подклассов PaginatorHelper и переопределяет метод. Это много копий и вставок, так как оригинальный метод очень длинный, и по этой причине я не включил его непосредственно в этот ответ.

Вы можете посмотреть его здесь: https://gist.github.com/2037902

Вам также необходимо добавить CustomPaginator в список помощников в контроллере.

1 голос
/ 20 ноября 2014

Я нашел еще более простое решение, никакой пользовательский код не нужен и будет так, как это делает CakePHP, может не работать в CakePHP 2.0 ниже версий, потому что я зарегистрировался в 2.5 ...

Для Paginatorsnumber() метод, вы всегда можете переопределить его default array(), который выглядит так:

$defaults = array(
            'tag' => 'span', 'before' => null, 'after' => null, 'model' => $this->defaultModel(), 'class' => null,
            'modulus' => '8', 'separator' => ' | ', 'first' => null, 'last' => null, 'ellipsis' => '...',
            'currentClass' => 'current', 'currentTag' => null
);

теперь мы можем переопределить эти значения по умолчанию в любое время, когда мы хотим просто использовать эти атрибуты в options array() дляпример в вашем случае:

    $this->Paginator->numbers(
                              array(
                                'separator' => ' - ',
                                'after' => '',
                                'before' => ''
    ));
1 голос
/ 24 августа 2013

Я нашел даже более простой способ достижения того же самого. Вы заметите, что PaginationHelper расширяет AppHelper. Итак, если вы скопируете какие-либо функции из PaginatorHelper в вызовы AppHelper и вызовете их из PaginationHelper, они будут вести себя так же и без каких-либо ошибок.

Использование

$numbers_config = array(
"before" => null,
"after" => null,
"separator" => "",
"tag" => "li"
);
echo $this->Paginator->customNumbers($numbers_config);

Код

// /app/View/AppHelper.php

App::uses('Helper', 'View');

class AppHelper extends Helper {

    public function customNumbers($options = array()) {
        if ($options === true) {
            $options = array(
                'before' => ' | ', 'after' => ' | ', 'first' => 'first', 'last' => 'last'
            );
        }

        $defaults = array(
            'tag' => 'span', 'before' => null, 'after' => null, 'model' => $this->defaultModel(), 'class' => null,
            'modulus' => '8', 'separator' => ' | ', 'first' => null, 'last' => null, 'ellipsis' => '...',
            'currentClass' => 'current', 'currentTag' => null
        );
        $options += $defaults;

        $params = (array)$this->params($options['model']) + array('page' => 1);
        unset($options['model']);

        if ($params['pageCount'] <= 1) {
            return false;
        }

        extract($options);
        unset($options['tag'], $options['before'], $options['after'], $options['model'],
            $options['modulus'], $options['separator'], $options['first'], $options['last'],
            $options['ellipsis'], $options['class'], $options['currentClass'], $options['currentTag']
        );

        $out = '';

        if ($modulus && $params['pageCount'] > $modulus) {
            $half = intval($modulus / 2);
            $end = $params['page'] + $half;

            if ($end > $params['pageCount']) {
                $end = $params['pageCount'];
            }
            $start = $params['page'] - ($modulus - ($end - $params['page']));
            if ($start <= 1) {
                $start = 1;
                $end = $params['page'] + ($modulus - $params['page']) + 1;
            }

            if ($first && $start > 1) {
                $offset = ($start <= (int)$first) ? $start - 1 : $first;
                if ($offset < $start - 1) {
                    $out .= $this->first($offset, compact('tag', 'separator', 'ellipsis', 'class'));
                } else {
                    $out .= $this->first($offset, compact('tag', 'separator', 'class', 'ellipsis') + array('after' => $separator));
                }
            }

            $out .= $before;

            for ($i = $start; $i < $params['page']; $i++) {
                $out .= $this->Html->tag($tag, $this->link($i, array('page' => $i), $options), compact('class')) . $separator;
            }

            if ($class) {
                $currentClass .= ' ' . $class;
            }
            if ($currentTag) {
                $out .= $this->Html->tag($tag, $this->Html->tag($currentTag, $params['page']), array('class' => $currentClass));
            } else {
                $out .= $this->Html->tag($tag, "<a href='#'>".$params['page']."</a>", array('class' => $currentClass));
            }
            if ($i != $params['pageCount']) {
                $out .= $separator;
            }

            $start = $params['page'] + 1;
            for ($i = $start; $i < $end; $i++) {
                $out .= $this->Html->tag($tag, $this->link($i, array('page' => $i), $options), compact('class')) . $separator;
            }

            if ($end != $params['page']) {
                $out .= $this->Html->tag($tag, $this->link($i, array('page' => $end), $options), compact('class'));
            }

            $out .= $after;

            if ($last && $end < $params['pageCount']) {
                $offset = ($params['pageCount'] < $end + (int)$last) ? $params['pageCount'] - $end : $last;
                if ($offset <= $last && $params['pageCount'] - $end > $offset) {
                    $out .= $this->last($offset, compact('tag', 'separator', 'ellipsis', 'class'));
                } else {
                    $out .= $this->last($offset, compact('tag', 'separator', 'class', 'ellipsis') + array('before' => $separator));
                }
            }

        } else {
            $out .= $before;

            for ($i = 1; $i <= $params['pageCount']; $i++) {
                if ($i == $params['page']) {
                    if ($class) {
                        $currentClass .= ' ' . $class;
                    }
                    if ($currentTag) {
                        $out .= $this->Html->tag($tag, $this->Html->tag($currentTag, $i), array('class' => $currentClass));
                    } else {
                        $out .= $this->Html->tag($tag, $i, array('class' => $currentClass));
                    }
                } else {
                    $out .= $this->Html->tag($tag, $this->link($i, array('page' => $i), $options), compact('class'));
                }
                if ($i != $params['pageCount']) {
                    $out .= $separator;
                }
            }

            $out .= $after;
        }

        return $out;
    }

}
1 голос
/ 20 марта 2012

Ответ за пользовательское разбиение на страницы в Cake PHP

Хороший пример того, когда вам это понадобится, - это если базовая БД не поддерживает синтаксис SQL LIMIT.Это верно для IBM DB2.Вы все еще можете использовать пагинацию CakePHP, добавив в модель пользовательский запрос.

Если вам нужно создать пользовательские запросы для генерации данных, которые вы хотите разбить на страницы, вы можете переопределить модели paginate () и paginateCount ()методы, используемые логикой контроллера пагинации.Вам также необходимо переопределить ядро ​​paginateCount (), этот метод ожидает те же аргументы, что и Model :: find ('count').В приведенном ниже примере используются некоторые функции, специфичные для Postgres, поэтому, пожалуйста, измените их в зависимости от используемой базы данных.

Спасибо посмотрите, поможет ли это

1 голос
/ 20 марта 2012

Вы можете показать ответ здесь

Custom-Query-Pagination

Вы также можете показать другой результат здесь.

http://www.endyourif.com/custom-pagination-query-in-cakephp/

...