我想在我的插件页面中显示分页,由我创建..我尝试了很多示例,但没有人工作..
如果有人能给出答案,我会感激不尽......注意:我希望在后端(在管理员中)不在前端分页
答案 0 :(得分:32)
简单步骤:
$pagenum = isset( $_GET['pagenum'] ) ? absint( $_GET['pagenum'] ) : 1;
查找记录总数
$limit = 10; // number of rows in page
$offset = ( $pagenum - 1 ) * $limit;
$total = $wpdb->get_var( "SELECT COUNT(`id`) FROM {$wpdb->prefix}table_name" );
$num_of_pages = ceil( $total / $limit );
给予限制:
$entries = $wpdb->get_results( "SELECT * FROM {$wpdb->prefix}table_name LIMIT $offset, $limit" );
将此代码添加到您想要分页的位置:
$page_links = paginate_links( array(
'base' => add_query_arg( 'pagenum', '%#%' ),
'format' => '',
'prev_text' => __( '«', 'text-domain' ),
'next_text' => __( '»', 'text-domain' ),
'total' => $num_of_pages,
'current' => $pagenum
) );
if ( $page_links ) {
echo '<div class="tablenav"><div class="tablenav-pages" style="margin: 1em 0">' . $page_links . '</div></div>';
}
答案 1 :(得分:7)
通用分页功能。
此示例在大型数据库中显示如下:
&lt;&lt; 上一页 1 2 3 4 5 6 7 8 9 ... 822 823 下一步 &gt;&gt;
或
&lt;&lt; 上一页 1 2 ... 815 < kbd> 816 817 818 819 820 821 822 823 下一步 &gt;&gt;
或
&lt;&lt; 上一页 1 2 ... 812 < kbd> 813 814 815 816 817 818 ... 822 823 下一步 &gt;&gt;
...享受
<?php
/*Max Number of results to show*/
$max = 10;
/*Get the current page eg index.php?pg=4*/
if(isset($_GET['pg'])){
$p = (int) $_GET['pg'];
}else{
$p = 1;
}
$limit = ($p - 1) * $max;
$prev = $p - 1;
$next = $p + 1;
$limits = (int)($p - 1) * $max;
//This is the query to get the current dataset (change api to suit)
$result = mysqli_query($res, 'SELECT * from yourtable limit '.$limits.','.$max.'');
//Get total records from db (change api to suit)
$totalres = mysqli_result($res, mysqli_query($res, 'SELECT COUNT(id) AS tot FROM yourtable"'),0);
//devide it with the max value & round it up
$totalposts = ceil($totalres / $max);
$lpm1 = $totalposts - 1;
echo pagination($totalposts, $p, $lpm1, $prev, $next);
//The function
function pagination($totalposts, $p, $lpm1, $prev, $next){
$adjacents = 3;
if($totalposts > 1)
{
$pagination .= "<center><div>";
//previous button
if ($p > 1)
$pagination.= "<a href=\"?pg=$prev\"><< Previous</a> ";
else
$pagination.= "<span class=\"disabled\"><< Previous</span> ";
if ($totalposts < 7 + ($adjacents * 2)){
for ($counter = 1; $counter <= $totalposts; $counter++){
if ($counter == $p)
$pagination.= "<span class=\"current\">$counter</span>";
else
$pagination.= " <a href=\"?pg=$counter\">$counter</a> ";}
}elseif($totalposts > 5 + ($adjacents * 2)){
if($p < 1 + ($adjacents * 2)){
for ($counter = 1; $counter < 4 + ($adjacents * 2); $counter++){
if ($counter == $p)
$pagination.= " <span class=\"current\">$counter</span> ";
else
$pagination.= " <a href=\"?pg=$counter\">$counter</a> ";
}
$pagination.= " ... ";
$pagination.= " <a href=\"?pg=$lpm1\">$lpm1</a> ";
$pagination.= " <a href=\"?pg=$totalposts\">$totalposts</a> ";
}
//in middle; hide some front and some back
elseif($totalposts - ($adjacents * 2) > $p && $p > ($adjacents * 2)){
$pagination.= " <a href=\"?pg=1\">1</a> ";
$pagination.= " <a href=\"?pg=2\">2</a> ";
$pagination.= " ... ";
for ($counter = $p - $adjacents; $counter <= $p + $adjacents; $counter++){
if ($counter == $p)
$pagination.= " <span class=\"current\">$counter</span> ";
else
$pagination.= " <a href=\"?pg=$counter\">$counter</a> ";
}
$pagination.= " ... ";
$pagination.= " <a href=\"?pg=$lpm1\">$lpm1</a> ";
$pagination.= " <a href=\"?pg=$totalposts\">$totalposts</a> ";
}else{
$pagination.= " <a href=\"?pg=1\">1</a> ";
$pagination.= " <a href=\"?pg=2\">2</a> ";
$pagination.= " ... ";
for ($counter = $totalposts - (2 + ($adjacents * 2)); $counter <= $totalposts; $counter++){
if ($counter == $p)
$pagination.= " <span class=\"current\">$counter</span> ";
else
$pagination.= " <a href=\"?pg=$counter\">$counter</a> ";
}
}
}
if ($p < $counter - 1)
$pagination.= " <a href=\"?pg=$next\">Next >></a>";
else
$pagination.= " <span class=\"disabled\">Next >></span>";
$pagination.= "</center>\n";
}
return $pagination;
}
?>
答案 2 :(得分:6)
我以不同的方式解决了这个问题。解决方案是here
我使用第二个选项,标题为“如何将分页添加到WordPress插件?”。 这提供了与WordPress几乎相同的分页功能。
不要忘记下载“pagination.class.php”文件,将其放在插件文件夹中,并在插件中包含此文件时提供适当的路径。