Расширенное использованиеСоздание собственных адаптеров к источникам данныхВы можете столкнуться с таким типом источника данных, для которого в Zend Framework-е не предусмотрено адаптера. В этом случае нужно создать собственный адаптер. Для этого нужно реализовать интерфейс Zend_Paginator_Adapter_Interface. Он включает в себя два метода:
Кроме того, нужно реализовать конструктор, который принимает источник данных в качестве параметра и сохраняет его в защищенном или закрытом свойстве. Как его обрабатывать - зависит от вас. Если вы когда-либо использовали SPL-интерфейс » Countable, то вам должно быть известно о назначении метода count(). В Zend_Paginator он возвращает общее количество элементов в наборе данных. Кроме того, объект Zend_Paginator предоставляет метод countAllItems() который служит посредником к методу адаптера count(). Метод getItems() ненамного сложнее. Он должен принимать смещение и количество элементов на странице и возвращать соответствующий кусок данных. В случае массива он мог бы выглядеть следующим образом: Посмотрите исходники адаптеров, входящих в поставку Zend Framework (все они реализуют Zend_Paginator_Adapter_Interface), чтобы получить представление о том, как можно реализовать свой адаптер. Создание своих стилей прокруткиПри создании своего стиля прокрутки реализуйте интерфейс Zend_Paginator_ScrollingStyle_Interface, который определяет единственный метод, getPages(): Этот метод должен определять номера пограничных страниц в ряде так называемых "локальных" страниц (т.е. страниц, которые находятся рядом с текущей страницей). Если только ваш стиль прокрутки не наследует от уже существующего (для примера смотрите Zend_Paginator_ScrollingStyle_Elastic), то этот метод должен иметь в конце что-то вроде следующего: Этим вызовом не делается ничего особенного. Этот метод просто для удобства - он проверяет на корректность верхний и нижний пределы и возвращает массив номеров страниц для постраничной навигации. Для того, чтобы использовать новый стиль прокрутки, следует указать Zend_Paginator-у, в какой директории этот стиль находится. Для этого сделайте следующее:
Возможности кэшированияМожно указать Zend_Paginator-у, чтобы он кэшировал получаемые данные, чтобы они не извлекались через адаптер всякий раз, когда будет в них нужда. Для этого просто передайте его методу setCache() экземпляр Zend_Cache_Core.
После того, как Zend_Paginator получит экземпляр Zend_Cache_Core, все данные будут кэшироваться. Иногда возникает необходимость отключать кэширование данных даже после того, как вы передали эекземпляр Zend_Cache_Core. Для этого вы можете использовать метод setCacheEnable().
После того, как был установлен объект для кэширования, данные будут сохраняться и извлекаться через него. Иногда бывает нужно очищать кэш вручную. Вы можете делать это через вызов метода clearPageItemCache($pageNumber). В качестве аргумента метод принимает номер страницы, кэш которой следует очистить. Если вызов производится без передачи параметра, то весь кэш будет очищен:
Изменение количества элементов на странице приведет к очищению всего кэша, поскольку после этого он должен потерять актуальность:
Можно также видеть данные в кэше и запрашивать их напрямую. Для этого может использоваться метод getPageItemCache():
Интерфейс Zend_Paginator_AdapterAggregateВ зависимости от разрабатываемого приложения может возникнуть потребность разбивать на страницы объекты, у которых внутренняя структура данных эквивалентна существующим адаптерам, но при этом вы не хотите нарушать инкапсуляцию для того, что предоставлять доступ к этим данным. В других случаях объект может участвовать в связи "имеет-адаптер" вместо связи "является-адаптером", которую предлагает Zend_Paginator_Adapter_Abstract. В этих случаях вы можете использовать интерфейс Zend_Paginator_AdapterAggregate, который по поведению значительно похож на интерфейс IteratorAggregate из расширения SPL.
Как видно из кода, интерфейс довольно небольшой и от вас ожидается только возврат экземпляра Zend_Paginator_Adapter_Abstract. Фабричный метод Zend_Paginator::factory и конструктор класса Zend_Paginator после этого распознают экземпляр Zend_Paginator_AdapterAggregate и обрабатывают его должным образом.
|