Zend_Paginator-Advanced.xml 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 15103 -->
  4. <sect1 id="zend.paginator.advanced">
  5. <title>高度な使用法</title>
  6. <sect2 id="zend.paginator.advanced.adapters">
  7. <title>独自のデータソースアダプタ</title>
  8. <para>
  9. 同梱のアダプタでは対応していないようなデータ形式を処理したくなることもあるでしょう。
  10. そんな場合は自分でアダプタを書く必要があります。
  11. </para>
  12. <para>
  13. そのためには
  14. <classname>Zend_Paginator_Adapter_Interface</classname>
  15. を実装しなければなりません。このインターフェイスでは
  16. 2 つのメソッドが必須となっています。
  17. </para>
  18. <itemizedlist>
  19. <listitem>
  20. <para>count()</para>
  21. </listitem>
  22. <listitem>
  23. <para>getItems($offset, $itemCountPerPage)</para>
  24. </listitem>
  25. </itemizedlist>
  26. <para>
  27. さらに、コンストラクタを実装してそのパラメータでデータソースを受け取り、
  28. protected あるいは private なプロパティにそれを保存する処理も作りたくなることでしょう。
  29. これをどのように実装するかはあなた次第です。
  30. </para>
  31. <para>
  32. これまでに SPL の
  33. <ulink url="http://www.php.net/~helly/php/ext/spl/interfaceCountable.html"><code>Countable</code></ulink>
  34. インターフェイスを使ったことがある方なら
  35. <code>count()</code> はおなじみでしょう。
  36. <classname>Zend_Paginator</classname> と組み合わせて使う場合、
  37. これはデータコレクション内の項目総数を返します。
  38. さらに、 <classname>Zend_Paginator</classname> のインスタンスには
  39. <code>countAllItems()</code> メソッドがあります。
  40. これはアダプタの <code>count()</code> メソッドへのプロキシです。
  41. </para>
  42. <para>
  43. <code>getItems()</code> メソッドは、ほんの少しだけ複雑です。
  44. これは、オフセットおよび 1 ページあたりの項目数を受け取ります。
  45. それにあわせて適切なデータを返す必要があります。
  46. 配列の場合はこのようになるでしょう。
  47. </para>
  48. <para>
  49. <programlisting role="php"><![CDATA[
  50. return array_slice($this->_array, $offset, $itemCountPerPage);
  51. ]]>
  52. </programlisting>
  53. </para>
  54. <para>
  55. 同梱のアダプタ (すべて <classname>Zend_Paginator_Adapter_Interface</classname>
  56. を実装しています) を見れば、
  57. 自分のアダプタでこれをどのように実装すればいいのか参考になるでしょう。
  58. </para>
  59. </sect2>
  60. <sect2 id="zend.paginator.advanced.scrolling-styles">
  61. <title>独自のスクロール形式</title>
  62. <para>
  63. 独自のスクロール形式を作成するには
  64. <classname>Zend_Paginator_ScrollingStyle_Interface</classname>
  65. を実装しなければなりません。このインターフェイスには
  66. <code>getPages()</code> メソッドが定義されています。
  67. </para>
  68. <para>
  69. <programlisting role="php"><![CDATA[
  70. public function getPages(Zend_Paginator $paginator, $pageRange = null);
  71. ]]>
  72. </programlisting>
  73. </para>
  74. <para>
  75. このメソッドは、いわゆる "ローカル" ページ
  76. (現在のページの周辺のページたち) の範囲のページの最小値・
  77. 最大値を計算しなければなりません。
  78. </para>
  79. <para>
  80. 他のスクロール形式を継承している (たとえば
  81. <classname>Zend_Paginator_ScrollingStyle_Elastic</classname>)
  82. のでない限り、自作のスクロール形式は必ずといっていいほど
  83. 次のようなコードで終わることになるでしょう。
  84. </para>
  85. <para>
  86. <programlisting role="php"><![CDATA[
  87. return $paginator->getPagesInRange($lowerBound, $upperBound);
  88. ]]>
  89. </programlisting>
  90. </para>
  91. <para>
  92. このコールには特別な意味はありません。
  93. 単に最小値と最大値の妥当性をチェックして、
  94. その範囲の配列を返しているだけです。
  95. </para>
  96. <para>
  97. 新しいスクロール形式が用意できたら、どのディレクトリからそれを探すのかを
  98. <classname>Zend_Paginator</classname> に通知する必要があります。
  99. そのためには、次のようにします。
  100. </para>
  101. <para>
  102. <programlisting role="php"><![CDATA[
  103. $prefix = 'My_Paginator_ScrollingStyle';
  104. $path = 'My/Paginator/ScrollingStyle/';
  105. Zend_Paginator::addScrollingStylePrefixPath($prefix, $path);
  106. ]]>
  107. </programlisting>
  108. </para>
  109. </sect2>
  110. <sect2 id="zend.paginator.advanced.caching">
  111. <title>キャッシュ機能</title>
  112. <para>
  113. <classname>Zend_Paginator</classname> は、渡されたデータをキャッシュする機能があります。
  114. これを使用すると、アダプタが毎回データを取得することを回避できます。
  115. アダプタのデータを自動的にキャッシュさせるよう設定するには、
  116. <code>setCache()</code> メソッドに <classname>Zend_Cache_Core</classname> のインスタンスを渡します。
  117. </para>
  118. <para>
  119. <programlisting role="php"><![CDATA[
  120. $paginator = Zend_Paginator::factory($someData);
  121. $fO = array('lifetime' => 3600, 'automatic_serialization' => true);
  122. $bO = array('cache_dir'=>'/tmp');
  123. $cache = Zend_cache::factory('Core', 'File', $fO, $bO);
  124. Zend_Paginator::setCache($cache);
  125. ]]>
  126. </programlisting>
  127. </para>
  128. <para>
  129. <classname>Zend_Paginator</classname> が <classname>Zend_Cache_Core</classname> のインスタンスを受け取ると、
  130. データがキャッシュされるようになります。キャッシュインスタンスを渡した後でも、
  131. 場合によってはデータをキャッシュしたくないこともあるでしょう。そんな場合は
  132. <code>setCacheEnable()</code> を使用します。
  133. </para>
  134. <para>
  135. <programlisting role="php"><![CDATA[
  136. $paginator = Zend_Paginator::factory($someData);
  137. // $cache は Zend_Cache_Core のインスタンスです
  138. Zend_Paginator::setCache($cache);
  139. // ... スクリプトの後半で次のようにすると
  140. $paginator->setCacheEnable(false);
  141. // キャッシュが無効になります
  142. ]]>
  143. </programlisting>
  144. </para>
  145. <para>
  146. キャッシュが設定されると、データは自動的に格納され、必要に応じて取り出されるようになります。
  147. キャッシュを手動で空にできると便利でしょう。そうするには
  148. <code>clearPageItemCache($pageNumber)</code> をコールします。
  149. 何もパラメータを渡さなければ、キャッシュ全体が空になります。
  150. ページ番号をパラメータとして渡すと、そのページのキャッシュを空にします。
  151. </para>
  152. <para>
  153. <programlisting role="php"><![CDATA[
  154. $paginator = Zend_Paginator::factory($someData);
  155. Zend_Paginator::setCache($cache);
  156. $items = $paginator->getCurrentItems();
  157. // これで 1 ページ目がキャッシュに入りました
  158. $page3Items = $paginator->getItemsByPage(3);
  159. // これで 3 ページ目がキャッシュに入りました
  160. // 3 ページ目のキャッシュをクリアします
  161. $paginator->clearPageItemCache(3);
  162. // すべてのキャッシュをクリアします
  163. $paginator->clearPageItemCache();
  164. ]]>
  165. </programlisting>
  166. </para>
  167. <para>
  168. 1 ページあたりのアイテム数を変更すると、キャッシュ全体が空になります。
  169. キャッシュの内容が無効になるからです。
  170. </para>
  171. <para>
  172. <programlisting role="php"><![CDATA[
  173. $paginator = Zend_Paginator::factory($someData);
  174. Zend_Paginator::setCache($cache);
  175. // アイテムを取得します
  176. $items = $paginator->getCurrentItems();
  177. // すべてのキャッシュデータが消去されます
  178. $paginator->setItemCountPerPage(2);
  179. ]]>
  180. </programlisting>
  181. </para>
  182. <para>
  183. キャッシュ内のデータを見たり、直接アクセスしたりすることもできます。その場合には
  184. <code>getPageItemCache()</code> を使用します。
  185. </para>
  186. <para>
  187. <programlisting role="php"><![CDATA[
  188. $paginator = Zend_Paginator::factory($someData);
  189. $paginator->setItemCountPerPage(3);
  190. Zend_Paginator::setCache($cache);
  191. // アイテムを取得します
  192. $items = $paginator->getCurrentItems();
  193. $otherItems = $paginator->getItemsPerPage(4);
  194. // キャッシュされたアイテムを二次元配列で取得します
  195. var_dump($paginator->getPageItemCache());
  196. ]]>
  197. </programlisting>
  198. </para>
  199. </sect2>
  200. </sect1>
  201. <!--
  202. vim:se ts=4 sw=4 et:
  203. -->