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]);
什么是SQL查询?您将其分配给$ row,但除了返回它之外,您似乎没有对其执行任何操作。如果这一段代码不需要知道$ row,那么它应该在一个单独的函数中。另外,如果可以避免使用字符串连接,则不会将字符串连接视为构建查询的智能方式,尤其是在不使用转义函数来确保无法进行SQL注入的情况下。 – GordonM
代码示例建议$ smarty __should__只存在于您的函数中。试试'global $ smarty;'让外部也可以访问,或者在你的函数外面插入数据到$ smarty – Waygood
Garh ...没有返回$ pages对象...我的问题更新显示了我的解决方案。 –