这篇文章将为大家详细讲解有关Zend Framework如何实现留言本分页功能,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
具体如下:
第一步:在我们的控制器里面,也就是indexController.php里找到indexAction这个动作.我们可以看到..在这个动作里.我们相关教程只是取数据..我们现在把这个动作(Action)改写成如下形式..如下代码(有注解):
function indexAction()
{
$message=new message();//实例化数据库类
//取到所有留言getAllMessage,getAllReMessage
//二个方法在Model(Message.php)里定义的
//取到所有回复数据
$this->view->arrReviews=$message->getAllReMessage();
$page =1;//高置默认页
$numPerPage = 3;//每页显示的条数
if(isset($_GET['page']) && is_numeric($_GET['page'])){
$page = $_GET['page'];//取到URL传过来的页数码
}
$array=$message->getAllMessage();//取到所有留言数据
$paginator = Zend_Paginator::factory($array);
$paginator->setCurrentPageNumber($page)
->setItemCountPerPage($numPerPage);
$this->view->paginator = $paginator;
echo $this->view->render('header.phtml');//显示模版头文件
echo $this->view->render('message/index.phtml');//显示模版
echo $this->view->render('footer.phtml');//显示模版脚文件
}
第二步:搞定我们要分页的样式,这里是以一个HTML设定分页的样式..在Zend Framework手册上.提供了三种分页显示的方式...大家可以自己去看一下他们的用法..其实很简单的..我运用了它的第一种.我们就在views/scripts/目录下建立一个新的模板页pagestyle.phtml..这个模板页是和留言本header.phtml以及footer.phtml同一级的..因为我们可能以后还会用到这个分页方式..所以我就放在这里..:pagestyle.phtml代码如下所示:(注意:在这里请在你的入口文件index.php定义一下你的WEB_ROOT为全局变量,它就是你网站根目录!):
if ($this->pageCount): ?>
class="paginationControl">
if (isset($this->previous)): ?>
"index/index/?page=
previous; ?> ">< 上一页 |
else: ?>
class="disabled">< 上一页 |
endif; ?>
foreach ($this->pagesInRange as $page): ?>
if ($page != $this->current): ?>
"index/index/?page=
">$page; ?> |
else: ?> = $page; ?> |
endif; ?> endforeach; ?>
if (isset($this->next)): ?>
"index/index/?page=
next; ?>">下一页 >
else: ?>
class="disabled">下一页 >
endif; ?>
endif; ?>
第三步:找到留言本显示页的index.pthml模板页,把原来:
foreach($this->messages as $message): ?>
这个换成
if (count($this->paginator)): ?>
$i=1; foreach ($this->paginator as $message): ?>
之后.我们再在最后面加一分页的显示:
= $this->paginationControl($this->paginator,
'Elastic', 'pagestyle.phtml'); ?>
关于“Zend Framework如何实现留言本分页功能”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。