アクセシビリティのために HTML ページネーションを生成します。
セキュリティパッケージ: https://github.com/rancoud/Security
作曲家にはrancoud/ページネーションが必要です
$currentPage = 1;$countElements = 10;$countElementPerPage = 5;$p = new Pagination();$html = $p->generateHtml($currentPage, $countElements, $countElementPerPage);echo $html;
出力されます
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li></ul></nav>
ルートは<ul>
を表します
項目は<li>
を表します
リンクは<a>
を表します
パラメータ | タイプ | デフォルト値 | 説明 |
---|---|---|---|
構成 | 配列 | [] | ページネーション動作を変更するためのパラメータ |
generateHtml(currentPage: int, countElements: int, countElementPerPage: int): string
generateData(currentPage: int, countElements: int, countElementPerPage: int): 配列
countPages(countElements: int, countElementPerPage: int): int
locateItemInPage(countElementPerPage: int、indexItem: int): int
URL(文字列)(例)
show_all_links (bool: false) (例)
use_previous (bool: false) (例)
always_use_previous (bool: false) (例)
use_next (bool: false) (例)
always_use_next (bool: false) (例)
use_dots (bool: false) (例)
count_pages_pair_limit (int: 0) (例)
count_pages_pair_adjacent (int: 2) (例)
text_previous (文字列: 前のページ) (例)
text_next (文字列: 次のページ) (例)
text_dots (文字列: …) (例)
text_page (文字列: {{PAGE}}) (例)
aria_label_link (文字列: ページ {{PAGE}} に移動) (例)
aria_label_current_link (文字列: 現在のページ、ページ {{PAGE}}) (例)
aria_label_nav (文字列: ページネーション) (例)
aria_label_previous (文字列: 前のページ) (例)
aria_label_next (文字列: 次のページ) (例)
千区切り文字 (文字列) (例)
root_tag (文字列: ul) (例)
root_attrs (文字列) (例)
use_nav (bool: true) (例)
nav_attrs (文字列) (例)
item_tag (文字列: li) (例)
item_attrs (文字列) (例)
item_attrs_current (文字列) (例)
item_previous_attrs (文字列) (例)
item_previous_attrs_disabled (文字列) (例)
item_next_attrs (文字列) (例)
item_next_attrs_disabled (文字列) (例)
item_dots_attrs (文字列) (例)
link_tag (文字列: a) (例)
link_attrs (文字列) (例)
link_attrs_current (文字列) (例)
link_previous_attrs_disabled (文字列) (例)
link_next_attrs_disabled (文字列) (例)
dot_tag (文字列:span) (例)
dot_attrs (文字列) (例)
use_pretty_html (ブール値: true) (例)
html_tab_sequence (文字列: t) (例)
html_initial_indentation (int: 0) (例)
esc_attr (bool: true) (例)
esc_html (bool: true) (例)
charset (文字列: UTF-8) (例)
これらのパラメータは自分でサニタイズする必要があります。
nav_attrs
root_attrs
item_attrs
item_attrs_current
item_previous_attrs
item_previous_attrs_disabled
item_next_attrs
item_next_attrs_disabled
item_dots_attrs
リンク属性
link_attrs_current
link_previous_attrs_disabled
link_next_attrs_disabled
ドット属性
html_tab_sequence
最後にページを追加
$conf = ['url' => 'https://example.com/news/page/'];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="Page 1" aria-current="page">1</a></li><li><a href="https://例。 com/news/page/2" aria-label="Page 2">2</a></li></ul></nav>
{{PAGE}} パターンによるページ置換
$conf = ['url' => 'https://example.com/news/page/{{PAGE}}/?date=desc'];echo (new Pagination($conf))->generateHtml(1, 10、5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="Page 1" aria-current="page">1</a></li><li><a href="https://例。 com/ニュース/ページ/2/?日付=desc" aria-label="ページ 2">2</a></li></ul></nav>
ページを {{PAGE}} パターンに置き換えた後
$conf = ['url' => '{{PAGE}}?date=desc'];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2?date=desc" aria-label= 「ページ 2">2</a></li></ul></nav>
⏫ 設定パラメータ/URL
$conf = ['show_all_links' => true];echo (new Pagination($conf))->generateHtml(1, 30, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li><li><a href="3" aria-label="Page 3">3</a></li><li><a href="4" aria-label="Page 4">4</a></li><li><a href="5" aria-label="Page 5">5</a></ li><li><a href="6" aria-label="Page 6">6</a></li></ul></nav>
⏫ 設定パラメータ/動作
$conf = ['use_previous' => true];echo (new Pagination($conf))->generateHtml(2, 10, 5);
<nav aria-label="ページネーション"><ul><li><a href="1" aria-label="前 page">前のページ</a></li><li><a href="1" aria-label="Page 1">1</a></li><li><a href="#" aria-label="ページ 2" aria-current="page">2</a></li></ul></nav>
⏫ 設定パラメータ/動作
前のページがない場合、リンクタグにaria-disabled=true
が含まれます
$conf = ['always_use_previous' => true];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="前のページ " aria-disabled="true">前のページ</a></li><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li></ul></nav>
⏫ 設定パラメータ/動作
$conf = ['use_next' => true];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li><li><a href="2" aria-label="Next page">次のページ</a></li></ul></nav>
⏫ 設定パラメータ/動作
次のページがない場合、Next はリンクタグにaria-disabled=true
持ちます
$conf = ['always_use_next' => true];echo (new Pagination($conf))->generateHtml(2, 10, 5);
<nav aria-label="Pagination"><ul><li><a href="1" aria-label="Page 1">1</a></li><li><a href ="#" aria-label="ページ 2" aria-current="page">2</a></li><li><a href="#" aria-label="次のページ" aria-disabled="true">次のページ</a></li></ul></nav>
⏫ 設定パラメータ/動作
$conf = ['use_dots' => true];echo (new Pagination($conf))->generateHtml(1, 30, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li><li><a href="3" aria-label="Page 3">3</a></li><li> aria-hidden="true"><span>…</span></li></ul></nav>
⏫ 設定パラメータ/動作
$conf = ['count_pages_pair_limit' => 1];echo (new Pagination($conf))->generateHtml(5, 300, 5);
<nav aria-label="Pagination"><ul><li><a href="1" aria-label="Page 1">1</a></li><li><a href ="3" aria-label="Page 3">3</a></li><li><a href="4" aria-label="Page 4">4</ a></li><li><a href="#" aria-label="ページ 5" aria-current="page">5</a></li><li><a href="6" aria-label="ページ 6"> 6</a></li><li><a href="7" aria-label="Page 7">7</a></li><li><a href="60" aria-label="ページ 60">60</a></li></ul></nav>
⏫ 設定パラメータ/動作
$conf = ['count_pages_pair_adjacent' => 1];echo (new Pagination($conf))->generateHtml(5, 300, 5);
<nav aria-label="Pagination"><ul><li><a href="4" aria-label="Page 4">4</a></li><li><a href ="#" aria-label="ページ 5" aria-current="page">5</a></li><li><a href="6" aria-label="ページ 6"> 6</a></li></ul></nav>
⏫ 設定パラメータ/動作
count_pages_pair_limit 0 + count_pages_pair_adjacent 0
$conf = ['count_pages_pair_limit' => 0,'count_pages_pair_adjacent' => 0];echo (new Pagination($conf))->generateHtml(5, 300, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="ページ 5" aria-current="page">5</a></li></ul></nav>
count_pages_pair_limit 2 + count_pages_pair_adjacent 2
$conf = ['count_pages_pair_limit' => 2,'count_pages_pair_adjacent' => 2];echo (new Pagination($conf))->generateHtml(5, 300, 5);
<nav aria-label="Pagination"><ul><li><a href="1" aria-label="Page 1">1</a></li><li><a href ="2" aria-label="Page 2">2</a></li><li><a href="3" aria-label="Page 3">3</ a></li><li><a href="4" aria-label="Page 4">4</a></li><li><a href="#" aria-label="ページ 5" aria-current="page">5</a></li><li><a href="6" aria-label="ページ 6"> 6</a></li><li><a href="7" aria-label="Page 7">7</a></li><li><a href="59" aria-label="Page 59">59</a></li><li><a href="60" aria-label="Page 60">60</a></リ></ul></nav>
⏫ 設定パラメータ/動作
$conf = ['use_previous' => true,'text_previous' => 'prev'];echo (new Pagination($conf))->generateHtml(2, 10, 5);
<nav aria-label="ページネーション"><ul><li><a href="1" aria-label="前 page">前</a></li><li><a href ="1" aria-label="Page 1">1</a></li><li><a href="#" aria-label="ページ 2" aria-current="page">2</a></li></ul></nav>
⏫ 設定パラメータ/ラベル
$conf = ['use_next' => true,'text_next' => 'next'];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li><li><a href="2" aria-label="次 page">次</a></li></ul></nav>
⏫ 設定パラメータ/ラベル
$conf = ['use_dots' => true,'text_dots' => 'dots'];echo (new Pagination($conf))->generateHtml(1, 30, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li><li><a href="3" aria-label="Page 3">3</a></li><li> aria-hidden="true"><span>ドット</span></li></ul></nav>
⏫ 設定パラメータ/ラベル
最後にページを追加
$conf = ['text_page' => 'yolo'];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="ページ 1" aria-current="page">yolo 1</a></li><li><a href="2" aria-label="ページ 2" >ヨロ 2</a></li></ul></nav>
{{PAGE}} パターンによるページ置換
$conf = ['text_page' => 'yo {{PAGE}} lo'];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="Page 1" aria-current="page">yo 1 lo</a></li><li><a href="2" aria-label="Page 2 ">よ 2 ろ</a></li></ul></nav>
⏫ 設定パラメータ/ラベル
$conf = ['aria_label_link' => 'aria label link'];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="aria label  ;link">2</a></li></ul></nav>
{{PAGE}} パターンあり
$conf = ['aria_label_link' => 'aria label link {{PAGE}}'];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="aria label  ;link 2">2</a></li></ul></nav>
⏫ 設定パラメータ/ラベル
$conf = ['aria_label_current_link' => 'aria label current link'];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="aria label current link" aria-current="page">1</a></li><li><a href="2" aria-label= 「ページ 2">2</a></li></ul></nav>
{{PAGE}} パターンによるページ置換
$conf = ['aria_label_current_link' => 'aria label current link {{PAGE}}'];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="aria label current link 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2">2</a></li></ul></nav>
⏫ 設定パラメータ/ラベル
$conf = ['aria_label_nav' => 'aria label nav'];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="aria label nav"><ul><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li></ul></nav>
⏫ 設定パラメータ/ラベル
$conf = ['use_previous' => true,'aria_label_previous' => 'prev'];echo (new Pagination($conf))->generateHtml(2, 10, 5);
<nav aria-label="Pagination"><ul><li><a href="1" aria-label="prev">前のページ</a></li><li><a href="1 " aria-label="Page 1">1</a></li><li><a href="#" aria-label="ページ 2" aria-current="page">2</a></li></ul></nav>
⏫ 設定パラメータ/ラベル
$conf = ['use_next' => true,'aria_label_next' => 'next'];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li><li><a href="2" aria-label="next">次のページ</a></li></ul></nav>
⏫ 設定パラメータ/ラベル
$conf = ['thousands_separator' => ';','count_pages_pair_limit' => 1];echo (new Pagination($conf))->generateHtml(1, 1000, 1);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li><li><a href="3" aria-label="Page 3">3</a></li><li><a href="1000" aria-label="ページ 1000">1;000</a></li></ul></nav>
⏫ 設定パラメータ/ラベル
$conf = ['root_tag' => 'root'];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><root><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li></root></nav>
⏫ 設定パラメータ / HTML マークアップ / ルート
$conf = ['root_attrs' => 'data-root="attrs"'];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="Pagination"><ul data-root="attrs"><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li></ul></nav>
⏫ 設定パラメータ / HTML マークアップ / ルート
$conf = ['use_nav' => false];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<ul><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li></ul>
⏫ 設定パラメータ / HTML マークアップ / ルート
$conf = ['nav_attrs' => 'data-item="attrs"'];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション" data-item="attrs"><ul><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li></ul></nav>
⏫ 設定パラメータ / HTML マークアップ / ルート
$conf = ['item_tag' => 'item'];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><ul><item><a href="#" aria-label="ページ 1" aria-current="page">1</a></item><item><a href="2" aria-label="ページ 2"> 2</a></item></ul></nav>
⏫ 設定パラメータ / HTML マークアップ / 項目
$conf = ['item_attrs' => 'data-item="attrs"'];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li data-item="attrs"><a href="2" aria-label="ページ 2">2</a></li></ul></nav>
{{PAGE}} パターンによるページ置換
$conf = ['item_attrs' => 'data-item="attrs {{PAGE}}"'];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li data-item="attrs 2"><a href="2" aria-label= 「ページ 2">2</a></li></ul></nav>
⏫ 設定パラメータ / HTML マークアップ / 項目
$conf = ['item_attrs_current' => 'data-item-current="attrs"'];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><ul><li data-item-current="attrs"><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li></ul></nav>
{{PAGE}} パターンによるページ置換
$conf = ['item_attrs_current' => 'data-item-current="attrs {{PAGE}}"'];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><ul><li data-item-current="attrs 1"><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li></ul></nav>
⏫ 設定パラメータ / HTML マークアップ / 項目
$conf = ['use_previous' => true,'item_previous_attrs' => 'data-item-previous="attrs"'];echo (new Pagination($conf))->generateHtml(2, 10, 5);
<nav aria-label="Pagination"><ul><li data-item-previous="attrs"><a href="1" aria-label="Previous page">前のページ</a> </li><li><a href="1" aria-label="Page 1">1</a></li><li><a href="#" aria-label="ページ 2" aria-current="page">2</a></li></ul></nav>
{{PAGE}} パターンによるページ置換
$conf = ['use_previous' => true,'item_previous_attrs' => 'data-item-previous="attrs {{PAGE}}"'];echo (new Pagination($conf))->generateHtml(2, 10) 、5);
<nav aria-label="Pagination"><ul><li data-item-previous="attrs 1"><a href="1" aria-label="Previous page">前のページ</a ></li><li><a href="1" aria-label="Page 1">1</a></li><li><a href="#" aria-label="ページ 2" aria-current="page">2</a></li></ul></nav>
⏫ 設定パラメータ / HTML マークアップ / 項目
$conf = ['always_use_previous' => true,'item_previous_attrs_disabled' => 'data-item-previous-disabled="attrs"'];echo (new Pagination($conf))->generateHtml(1, 10, 5) ;
<nav aria-label="Pagination"><ul><li data-item-previous-disabled="attrs"><a href="#" aria-label="前のページ " aria-disabled="true">前のページ</a></li><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li></ul></nav>
{{PAGE}} パターンによるページ置換
$conf = ['always_use_previous' => true,'item_previous_attrs_disabled' => 'data-item-previous-disabled="attrs {{PAGE}}"'];echo (new Pagination($conf))->generateHtml(1) 、10、5);
<nav aria-label="Pagination"><ul><li data-item-previous-disabled="attrs 0"><a href="#" aria-label="前のページ " aria-disabled="true">前のページ</a></li><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li></ul></nav>
⏫ 設定パラメータ / HTML マークアップ / 項目
$conf = ['use_next' => true,'item_next_attrs' => 'data-item-next="attrs"'];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li><li data-item-next="attrs"><a href="2" aria-label="Next page">次のページ</a></li> </ul></nav>
{{PAGE}} パターンによるページ置換
$conf = ['use_next' => true,'item_next_attrs' => 'data-item-next="attrs {{PAGE}}"'];echo (new Pagination($conf))->generateHtml(1, 10) 、5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li><li data-item-next="attrs 2"><a href="2" aria-label="Next page">次のページ</a></li ></ul></nav>
⏫ 設定パラメータ / HTML マークアップ / 項目
$conf = ['always_use_next' => true,'item_next_attrs_disabled' => 'data-item-next-disabled="attrs"'];echo (new Pagination($conf))->generateHtml(2, 10, 5) ;
<nav aria-label="Pagination"><ul><li><a href="1" aria-label="Page 1">1</a></li><li><a href ="#" aria-label="Page 2" aria-current="page">2</a></li><li data-item-next-disabled="attrs"><a href="# ;" aria-label="次のページ" aria-disabled="true">次のページ</a></li></ul></nav>
{{PAGE}} パターンによるページ置換
$conf = ['always_use_next' => true,'item_next_attrs_disabled' => 'data-item-next-disabled="attrs {{PAGE}}"'];echo (new Pagination($conf))->generateHtml(2) 、10、5);
<nav aria-label="Pagination"><ul><li><a href="1" aria-label="Page 1">1</a></li><li><a href ="#" aria-label="Page 2" aria-current="page">2</a></li><li data-item-next-disabled="attrs 2"><a href="&# ×23;" aria-label="次のページ" aria-disabled="true">次のページ</a></li></ul></nav>
⏫ 設定パラメータ / HTML マークアップ / 項目
$conf = ['use_dots' => true,'item_dots_attrs' => 'data-item-dots="attrs"'];echo (new Pagination($conf))->generateHtml(1, 30, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li><li><a href="3" aria-label="Page 3">3</a></li><li data-item-dots="attrs 」 aria-hidden="true"><span>…</span></li></ul></nav>
⏫ 設定パラメータ / HTML マークアップ / 項目
$conf = ['link_tag' => 'link'];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><ul><li><link href="#" aria-label="ページ 1" aria-current="page">1</link></li><li><link href="2" aria-label="ページ 2"> 2</link></li></ul></nav>
⏫ 設定パラメータ / HTML マークアップ / リンク
$conf = ['link_attrs' => 'data-link="attrs"'];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a data-link="attrs" href="2" aria-label="ページ 2">2</a></li></ul></nav>
{{PAGE}} パターンによるページ置換
$conf = ['link_attrs' => 'data-link="attrs {{PAGE}}"'];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a data-link="attrs 2" href="2" aria-label= 「ページ 2">2</a></li></ul></nav>
⏫ 設定パラメータ / HTML マークアップ / リンク
$conf = ['link_attrs_current' => 'data-link-current="attrs"'];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><ul><li><a data-link-current="attrs" href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li></ul></nav>
{{PAGE}} パターンによるページ置換
$conf = ['link_attrs_current' => 'data-link-current="attrs {{PAGE}}"'];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><ul><li><a data-link-current="attrs 1" href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li></ul></nav>
⏫ 設定パラメータ / HTML マークアップ / リンク
$conf = ['always_use_previous' => true,'link_previous_attrs_disabled' => 'data-item-next-disabled="attrs"'];echo (new Pagination($conf))->generateHtml(1, 10, 5) ;
<nav aria-label="Pagination"><ul><li><a data-item-next-disabled="attrs" href="#" aria-label="前のページ " aria-disabled="true">前のページ</a></li><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li></ul></nav>
{{PAGE}} パターンによるページ置換
$conf = ['always_use_previous' => true,'link_previous_attrs_disabled' => 'data-item-next-disabled="attrs {{PAGE}}"'];echo (new Pagination($conf))->generateHtml(1) 、10、5);
<nav aria-label="ページネーション"><ul><li><a data-item-next-disabled="attrs 0" href="#" aria-label="前のページ " aria-disabled="true">前のページ</a></li><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li></ul></nav>
⏫ 設定パラメータ / HTML マークアップ / リンク
$conf = ['always_use_next' => true,'link_next_attrs_disabled' => 'data-item-next-disabled="attrs"'];echo (new Pagination($conf))->generateHtml(2, 10, 5) ;
<nav aria-label="Pagination"><ul><li><a href="1" aria-label="Page 1">1</a></li><li><a href ="#" aria-label="Page 2" aria-current="page">2</a></li><li><a data-item-next-disabled="attrs" href="# ;" aria-label="次のページ" aria-disabled="true">次のページ</a></li></ul></nav>
{{PAGE}} パターンによるページ置換
$conf = ['always_use_next' => true,'link_next_attrs_disabled' => 'data-item-next-disabled="attrs {{PAGE}}"'];echo (new Pagination($conf))->generateHtml(2) 、10、5);
<nav aria-label="Pagination"><ul><li><a href="1" aria-label="Page 1">1</a></li><li><a href ="#" aria-label="Page 2" aria-current="page">2</a></li><li><a data-item-next-disabled="attrs 2" href="&# ×23;" aria-label="次のページ" aria-disabled="true">次のページ</a></li></ul></nav>
⏫ 設定パラメータ / HTML マークアップ / リンク
$conf = ['use_dots' => true,'dot_tag' => 'p'];echo (new Pagination($conf))->generateHtml(1, 30, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li><li><a href="3" aria-label="Page 3">3</a></li><li> aria-hidden="true"><p>…</p></li></ul></nav>
⏫ 設定パラメータ / HTML マークアップ / リンク
$conf = ['use_dots' => true,'dot_attrs' => 'data-dot="attrs"'];echo (new Pagination($conf))->generateHtml(1, 30, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li><li><a href="3" aria-label="Page 3">3</a></li><li aria-hidden="true"> <スパンdata-dot="attrs">…</span></li></ul></nav>
⏫ 設定パラメータ / HTML マークアップ / リンク
$conf = ['use_pretty_html' => false];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li></ul></nav>
⏫ 設定パラメータ / HTML マークアップ / インデント
$conf = ['html_tab_sequence' => ''];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li></ul></nav>
⏫ 設定パラメータ / HTML マークアップ / インデント
$conf = ['html_initial_indentation' => 1];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li></ul></nav>
⏫ 設定パラメータ / HTML マークアップ / インデント
$conf = ['esc_attr' => false];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li> ><a href="2" aria-label="Page 2">2</a></li></ul></nav>
⏫ 設定パラメータ / HTML マークアップ / セキュリティ
$conf = ['esc_html' => false,'text_page' => '<em>{{PAGE}}</em>'];echo (new Pagination($conf))->generateHtml(1, 10, 5) );
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="ページ 1" aria-current="page"><em>1</em></a></li><li><a href="2" aria-label="ページ 2"><em>2</em></a></li></ul></nav>
⏫ 設定パラメータ / HTML マークアップ / セキュリティ
$conf = ['charset' => 'EUC-JP'];echo (new Pagination($conf))->generateHtml(1, 10, 5);
<nav aria-label="ページネーション"><ul><li><a href="#" aria-label="ページ 1" aria-current="page">1</a></li><li><a href="2" aria-label="ページ 2"> 2</a></li></ul></nav>
⏫ 設定パラメータ / HTML マークアップ / セキュリティ
$conf = ['always_use_previous' => true,'always_use_next' => true,'use_dots' => true, ]var_dump(new Pagination($conf))->generateData(1, 3000, 5);array (size=3) 'previous' => object(RancoudPaginationItem)[2] public 'ariaLabel' => string '前のページ' (長さ=18) パブリック 'href' => 文字列 '#' (長さ=6) パブリック 'itemAttrs' => 文字列 '' (長さ=0) public 'linkAttrs' => 文字列 '' (長さ=0) public 'text' => string '前のページ' (長さ=13) public 'isCurrent' => ブール値 false public 'isDots' => ブール値 false public 'isDisabled' => ブール値 true パブリック 'ページ' => int 0 'リンク' => 配列 (サイズ=4) 0 => オブジェクト(RancoudPaginationItem)[4] public 'ariaLabel' => 文字列 'Page 1' (length=11) public 'href' => 文字列 '#' (長さ=6) パブリック 'itemAttrs' => 文字列 '' (長さ=0) public 'linkAttrs' => 文字列 '' (長さ=0) パブリック 'テキスト' => 文字列 '1' (長さ=1) public 'isCurrent' => ブール値 true public 'isDots' => ブール値 false public 'isDisabled' => ブール値 false パブリック 'ページ' => int 1 1 => オブジェクト(RancoudPaginationItem)[5] public 'ariaLabel' => 文字列 'Page 2' (長さ=11) public 'href' => 文字列 '2' (長さ=1) public 'itemAttrs' => 文字列 '' (長さ=0) public 'linkAttrs' => 文字列 '' (長さ=0) パブリック 'テキスト' => 文字列 '2' (長さ=1) public 'isCurrent' => ブール値 false public 'isDots' => ブール値 false public 'isDisabled' => ブール値 false パブリック 'ページ' => int 2 2 => オブジェクト(RancoudPaginationItem)[6] public 'ariaLabel' => 文字列 'Page 3' (長さ=11) public 'href' => 文字列 '3' (長さ=1) public 'itemAttrs' => 文字列 '' (長さ=0) public 'linkAttrs' => 文字列 '' (長さ=0) パブリック 'テキスト' => 文字列 '3' (長さ=1) public 'isCurrent' => ブール値 false public 'isDots' => ブール値 false public 'isDisabled' => ブール値 false パブリック 'ページ' => int 3 3 => オブジェクト(RancoudPaginationItem)[7] public 'ariaLabel' => 文字列 'Page 4' (長さ=11) public 'href' => 文字列 '4' (長さ=1) public 'itemAttrs' => 文字列 '' (長さ=0) public 'linkAttrs' => 文字列 '' (長さ=0) パブリック 'テキスト' => 文字列 '…' (長さ=3) public 'isCurrent' => ブール値 false public 'isDots' => ブール値 true public 'isDisabled' => ブール値 false パブリック 'ページ' => int 4 '次へ' => オブジェクト(RancoudPaginationItem)[8] public 'ariaLabel' => 文字列 '次のページ' (長さ=14) public 'href' => 文字列 '2' (長さ=1) public 'itemAttrs' => 文字列 '' (長さ=0) public 'linkAttrs' => 文字列 '' (長さ=0) public 'text' => string '次のページ' (長さ=9) public 'isCurrent' => ブール値 false public 'isDots' => ブール値 false public 'isDisabled' => ブール値 false パブリック 'ページ' => int 2
php-cs-fixer および phpunit およびカバレッジ用のcomposer ci
php-cs-fixer 用のcomposer lint
phpunit とカバレッジのcomposer test