Paginator类

时间:2009-11-15 02:46:31

标签: php mysql pagination smarty

大家。我正在使用php和mysql数据库在智能模板上工作。 这是一个比我第一个询问如何将方法传递给类更具体的问题。我认为重新打包问题比编辑旧问题更容易。

我为我的图片库编写了一个分页器脚本,该脚本在页面上显示图像。如果用户选择了类别,则仅显示特定类别中的图像,并且结果始终是分页的。 脚本如下所示。

$page_num = (isset($_GET['page_num']))?$_GET['page_num']:1;   //if $_GET['page_num'] is set then assign to var  $page_num. Otherwise set $page_num = 1 for first page
$category = (isset($_GET['req1']))?$_GET['req1']:'null';        //if $_GET['req1'] is set assign to $category other set $category to null

$items_pp = 5;
$total = $db->num_images_gallery($category);     //returns the number of records in total('null') or in a particular category('category_name')
$pages_required = ceil($total/$items_pp);  //total records / records to display per page rounded up
if($page_num > $pages_required){//in case the current page number is greater that the pages required then set it to the amount of pages required
    $page_num = $pages_required;
}
if($page_num < 1){//in case the current page num is set to less that one set it back to 1
    $page_num = 1;
}
$limit = "LIMIT " .($page_num - 1)*$items_pp . "," . $items_pp . ""; //if 5 results pre page and we on page 3 then LIMIT 10,5 that is record 10,11,12,13 and 14
$result = $db->get_images_gallery($category,$limit);

$i = 0;
while($row = $result->fetch_assoc()){
    $images[$i]['file']         =$row['file'];
    $images[$i]['file_thumb']   = str_replace('.','_thumbnail.',$row['file']);//show the thumbnail version of the image on the page
    $images[$i]['title']        = $row['title'];
    $images[$i]['description']  = $row['description'];
    $i++;
}
if(!empty($images)){
$smarty->assign('images',$images);}else{
$smarty->assign('message',"There are no images to display in the ".ucwords(str_replace('_',' ',$category))." category");}

if($total > 0 && $pages_required >= 1){//only display this navigation if there are images to display and more than one page

    $smarty->assign('page_scroll',$page_num . ' of ' . $pages_required);
    $page_scroll_first = "<a href='".$_SERVER['REDIRECT_URL'] . "?page_num=1"."' >FIRST</a> <a href='".$_SERVER['REDIRECT_URL'] . "?page_num=" . ($page_num-1)."' >&lt;&lt;PREVIOUS</a>";
    $page_scroll_last =  " <a href='".$_SERVER['REDIRECT_URL'] . "?page_num=". ($page_num+1) . "'>NEXT&gt;&gt;</a> <a href='" . $_SERVER['REDIRECT_URL'] . "?page_num=".$pages_required."'>LAST</a>";
    if($page_num == 1){$page_scroll_first = "FIRST &lt;&lt;PREVIOUS";}
    if($page_num == $pages_required){$page_scroll_last = "NEXT&gt;&gt; LAST";}
    $smarty->assign('page_scroll_first',$page_scroll_first);//just use if statements to set the values for page scroll first and page scroll last and then assign them here
    $smarty->assign('page_scroll_last',$page_scroll_last);
    $smarty->assign('page_num',$page_num);

}

该脚本调用我的数据库类中的两个方法: $ db-&gt; num_images_gallery看起来像这样:

function num_images_gallery($cat='null'){

    $query = ($cat == 'null')?
    "SELECT COUNT(*) AS images FROM images
    LEFT JOIN image_categories ON (images.image_categories_id = image_categories.id)
    WHERE images.gallery='1' AND image_categories.gallery = '1'"//no images should be shown in a category which is not intended to be shown at all
    :
    "SELECT COUNT(*) AS images FROM images
    LEFT JOIN image_categories ON (images.image_categories_id = image_categories.id)
    WHERE category = '{$cat}'
    AND images.gallery='1' AND image_categories.gallery = '1'";

    $result = $this->connection->query('SELECT COUNT(*) AS images FROM (?)',$x);
    $row = $result->fetch_assoc();
    $row_count = $row['images'];
    echo $row_count;
    return $row_count;  
}

和方法$ db :: get_images_gallery()看起来像这样:

function get_images_gallery($category,$limit){
    $query = ($category=='null')?
        "SELECT `file`,title,images.description,sizes,images.gallery,category FROM images
        LEFT JOIN image_categories ON (images.image_categories_id = image_categories.id) WHERE images.gallery='1' AND image_categories.gallery = '1' {$limit}"
        :
        "SELECT `file`,title,images.description,sizes,images.gallery,category FROM images
        LEFT JOIN image_categories ON (images.image_categories_id = image_categories.id)
        WHERE category = '{$category}' AND images.gallery='1' AND image_categories.gallery = '1' {$limit}";
        $result = $this->connection->query($query);
        return $result;
    }

我现在想要创建一个名为paginate的类并将此脚本放入其中,以便我可以显示我的网站产品分页。 主要问题是我需要使用不同的函数来获取产品表中的产品数量,然后返回分页结果。如何将上面的脚本转换为可以更改所使用的功能的类。我几乎得到了previous question的答案,但问题不够具体。 谢谢 安德鲁

1 个答案:

答案 0 :(得分:3)

有一个Smarty附加组件用于分页。

您可以在此处找到它:http://www.phpinsider.com/php/code/SmartyPaginate/

有关快速示例,请从链接页面中提取:

的index.php

session_start();
require('Smarty.class.php');
require('SmartyPaginate.class.php');

$smarty =& new Smarty;

// required connect
SmartyPaginate::connect();
// set items per page
SmartyPaginate::setLimit(25);

// assign your db results to the template
$smarty->assign('results', get_db_results());
// assign {$paginate} var
SmartyPaginate::assign($smarty);
// display results
$smarty->display('index.tpl');

function get_db_results() {
    // normally you would have an SQL query here,
    // for this example we fabricate a 100 item array
    // (emulating a table with 100 records)
    // and slice out our pagination range
    // (emulating a LIMIT X,Y MySQL clause)
    $_data = range(1,100);
    SmartyPaginate::setTotal(count($_data));
    return array_slice($_data, SmartyPaginate::getCurrentIndex(),
        SmartyPaginate::getLimit());
}

在index.tpl

{* display pagination header *}
Items {$paginate.first}-{$paginate.last} out of {$paginate.total} displayed.

{* display results *}    
{section name=res loop=$results}
    {$results[res]}
{/section}

{* display pagination info *}
{paginate_prev} {paginate_middle} {paginate_next}

关于混合DB类和Paginator类的问题,一切正常:
您的DB类将处理从数据库中获取数据 SmartyPaginate类将处理分页
并且你的index.php只是在适当的时候调用每一个来设置。

这个想法是将责任分开。
您的数据库类不会处理分页,您的分页类也不会包含数据库代码。

从你的另一个问题来看,我认为你正试图为手头的问题做一些太复杂的事情。

我建议您将所有与数据库相关的代码移到您的数据库处理类中以及index.php

之外

这个,例如:

$limit = "LIMIT " .($page_num - 1)*$items_pp . "," . $items_pp . ""; //if 5 results pre page and we on page 3 then LIMIT 10,5 that is record 10,11,12,13 and 14

这是DB逻辑,它生成(部分)SQL字符串,所以移动它 它取决于2个参数,因此找到一种方法让它们可用 在这种情况下,我建议只将两者作为参数传递。

而不是:

$result = $db->get_images_gallery($category,$limit);

使用:

$result = $db->get_images_gallery($category,$no_items, $page);

此外,您的寻呼机导航规则应该在您的paginator类中。

if($total > 0 && $pages_required >= 1){//only display this navigation if there are images to display and more than one page

    $smarty->assign('page_scroll',$page_num . ' of ' . $pages_required);
    $page_scroll_first = "<a href='".$_SERVER['REDIRECT_URL'] . "?page_num=1"."' >FIRST</a> <a href='".$_SERVER['REDIRECT_URL'] . "?page_num=" . ($page_num-1)."' >&lt;&lt;PREVIOUS</a>";
    $page_scroll_last =  " <a href='".$_SERVER['REDIRECT_URL'] . "?page_num=". ($page_num+1) . "'>NEXT&gt;&gt;</a> <a href='" . $_SERVER['REDIRECT_URL'] . "?page_num=".$pages_required."'>LAST</a>";
    if($page_num == 1){$page_scroll_first = "FIRST &lt;&lt;PREVIOUS";}
    if($page_num == $pages_required){$page_scroll_last = "NEXT&gt;&gt; LAST";}
    $smarty->assign('page_scroll_first',$page_scroll_first);//just use if statements to set the values for page scroll first and page scroll last and then assign them here
    $smarty->assign('page_scroll_last',$page_scroll_last);
    $smarty->assign('page_num',$page_num);

}

在这种情况下,我希望Add-On会自动为您处理。

然后你可以移动整个块,它可以将所有逻辑用于获取和准备图像数据到一个函数(如果有的话,在ImageGalery类中)

$total = $db->num_images_gallery($category);     //returns the number of records in total('null') or in a particular category('category_name')
$pages_required = ceil($total/$items_pp);  //total records / records to display per page rounded up
if($page_num > $pages_required){//in case the current page number is greater that the pages required then set it to the amount of pages required
    $page_num = $pages_required;
}
if($page_num < 1){//in case the current page num is set to less that one set it back to 1
    $page_num = 1;
}
$limit = "LIMIT " .($page_num - 1)*$items_pp . "," . $items_pp . ""; //if 5 results pre page and we on page 3 then LIMIT 10,5 that is record 10,11,12,13 and 14
$result = $db->get_images_gallery($category,$limit);

$i = 0;
while($row = $result->fetch_assoc()){
    $images[$i]['file']         =$row['file'];
    $images[$i]['file_thumb']   = str_replace('.','_thumbnail.',$row['file']);//show the thumbnail version of the image on the page
    $images[$i]['title']        = $row['title'];
    $images[$i]['description']  = $row['description'];
    $i++;
}

最后,在index.php上,您所要做的就是:
验证您收到的参数
调用ImageGalery类来获取galery数据(传递它需要的参数)
打电话给您的分页班进行分页(设置导航链接等)
设置所需的Smarty模板变量 并显示它。

仍有很大的改进空间,但我希望这几个步骤可以帮助您更清楚地了解Image Galery代码。