2013-06-27 60 views
1

我想使用 http://net.tutsplus.com/tutorials/php/how-to-paginate-data-with-php/中的paginator类,但由于某种原因,我无法在我的模板中输出smarty var中的分页链接。smarty变量不会输出

我已经试过这样:

function listadverts($where = null, $orderby = null, $limit = null) {   

     $pages = new Paginator; 
     $pages->items_total = $this->countadverts($where); 
     $pages->mid_range = 9; 
     $pages->paginate(); 

     $row = $this->db->dbh->query('SELECT ad.*, (SELECT img.image FROM '.$this->config->db_prefix.'_images AS img WHERE img.aid = ad.aid LIMIT 1) AS img FROM '.$this->config->db_prefix.'_adverts ad WHERE (ad.approved = 1) '. $where .' ORDER BY '.$orderby.' cr_date DESC '. $pages->limit .''); 

     $smarty = new Smarty(); 

     $smarty->assign('paginate', $pages->display_pages()); 
     return $row; 
    } 

,在我的模板,我有

{$paginate} 

功能

$pages->display_pages() 

回报$this->return;

其中$这个 - >换货政... RNS包含此HTML

$this->return .= ($i == $this->current_page) ? "<a class=\"current\" href=\"#\">$i</a> ":"<a class=\"paginate\" href=\"$target?page=$i&ipp=$this->items_per_page\">$i</a> "; 

{$ PAGINATE | @var_dump}刚刚返回NULL,但如果我的var_dump($ Smarty的),我可以看到

["paginate"]=> object(Smarty_Variable)#114 (3) { ["value"]=> string(227) "1 2 3 4 All " 

SOLUTION:

return array(0 => $row, 1 => $pages->display_pages()); 

$res = $adverts->listadverts();  
$app->view()->setData('adverts', $res[0]); 
$app->view()->setData('paginate', $res[1]); 
+0

什么是SQL查询?您将其分配给$ row,但除了返回它之外,您似乎没有对其执行任何操作。如果这一段代码不需要知道$ row,那么它应该在一个单独的函数中。另外,如果可以避免使用字符串连接,则不会将字符串连接视为构建查询的智能方式,尤其是在不使用转义函数来确保无法进行SQL注入的情况下。 – GordonM

+0

代码示例建议$ smarty __should__只存在于您的函数中。试试'global $ smarty;'让外部也可以访问,或者在你的函数外面插入数据到$ smarty – Waygood

+0

Garh ...没有返回$ pages对象...我的问题更新显示了我的解决方案。 –

回答

1

的代码示例建议$ smarty应该只存在于你的函数中。尝试全球$ smarty;也可以在外部访问或在您的功能之外插入数据到$ smarty

function listadverts($where = null, $orderby = null, $limit = null) { 

    $pages = new Paginator; 
    $pages->items_total = $this->countadverts($where); 
    $pages->mid_range = 9; 
    $pages->paginate(); 

    $row = $this->db->dbh->query('SELECT ad.*, (SELECT img.image FROM '.$this->config->db_prefix.'_images AS img WHERE img.aid = ad.aid LIMIT 1) AS img FROM '.$this->config->db_prefix.'_adverts ad WHERE (ad.approved = 1) '. $where .' ORDER BY '.$orderby.' cr_date DESC '. $pages->limit .''); 

    return $pages->display_pages(); 
} 

$smarty = new Smarty(); 
$smarty->assign('paginate', listadverts(...));