thinkphp中对数组元素进行分页显示
2017-03-15 00:00
267 查看
PHP模块代码: class NewsAction extends Action{ public $page = ''; //分页,当前页数 function News(){ $list = M("News")->field('id,title')->where("status = 5")->findAll(); //分页 $list = $this->array_page($list); //结束 $num = 0; $URL = "http://www.baidu.com/"; $suffixName = '.html'; foreach($list as $key=>$val){ $num = $key + 1; $str .= ' '.$num.").<a href='".$URL.$val['id'].$suffixName."' target='_blank'>".$val['title']."</a><br> "; } $str = preg_replace('/(.*),\s$/','\\1',$str); $str .= "<div class='d_page'>".$this->page."</div>"; return $str; } //数组分页方法 /** * array $array 数组 * integer $showCount 每页的记录数 *------------------------------ * return array 返回数组 */ function array_page($array,$listRows = 12,$showCount = 4){ $p = C('VAR_PAGE'); $url = $_SERVER['REQUEST_URI']."/".$p."/"; $page = !empty($_GET[C('VAR_PAGE')])?$_GET[C('VAR_PAGE')]:1; $upRow = $page-1; $downRow = $page+1; $linkPage = ""; $totalPage = (int)count($array); $pagetotal = ceil($totalPage/$listRows); //总页数 if($page <= ceil(($showCount)/2)){ $minpg = 1; $maxpg = $showCount+1; if($maxpg >= $pagetotal) $maxpg = $pagetotal + 1; }elseif($page > ceil(($showCount)/2) && $page < ($pagetotal - ceil($showCount/2))){ $minpg = $page - ceil(($showCount)/2) + 1; $maxpg = $page + ceil(($showCount)/2) + 1; if($maxpg >= $pagetotal) $maxpg = $pagetotal; }elseif($page >=$pagetotal - ceil(($showCount)/2)){ $minpg = $pagetotal - ($showCount-1); if($minpg == 1) $minpg = 2; $maxpg = $pagetotal + 1; } $linkPage .= " ".$totalPage." 条记录 ".$page."/".$pagetotal." 页 "; if($pagetotal == 1){ $linkPage .= " <span class='current'>1</span> "; }else{ if($page > 1){ $linkPage .= " <a href='javascript:void(0)' onClick=\"showpage('".$url."1');\">第一页</a>"; $linkPage .= " <a href='javascript:void(0)' onClick=\"showpage('".$url.$upRow."');\">上一页</a>"; } for($i = $minpg; $i < $maxpg; $i++){ if($page == $i){ $linkPage .= " <span class='current'><font color=\"#FF0000\">". $i ."</font></span>"; }else{ $linkPage .= " <a href='javascript:void(0)' onClick=\"showpage('".$url.$i."');\">$i</a>"; } } if($page < $pagetotal){ $linkPage .= " <a href='javascript:void(0)' onClick=\"showpage('".$url.$downRow."');\">下一页</a>"; $linkPage .= " <a href='javascript:void(0)' onClick=\"showpage('".$url.$pagetotal."');\">最后一页</a>"; } } if($listRows < $totalPage) { if($page <= 1 || empty($page)) { $page = 0; } else { $page = intval($page) - 1; } $array = array_slice($array,$page*$listRows,$listRows,true); } $this->page = $linkPage; if(1 == $pagetotal) $this->page = ''; return $array; } } 前台Html代码: <html> <head> <script type="text/javascript" charset="utf-8" src="__PUBLIC__/js/artDialog/artDialog.min.js"></script> </head> <body> <script language="javascript" type="text/javascript"> //分页跳转 function showpage(url){ var testDialog; testDialog = dialog('正在加载中...'); $.get(url,null,function(data){ //$("#con").append(data); testDialog.close(); $("#con").html(data); }); } //提示缓冲框 function dialog(msg){ var testDialog; testDialog = art.dialog({ lock: false, title:'', id:'loaddialog', content:'<font color="#ff0000">'+msg+'</font>', width:220 }); return testDialog; } </script> 7fe0 <div id="con"></div> </body> </html>
相关文章推荐
- thinkphp中对数组元素进行分页显示
- thinkphp-根据关键字查询并进行分页显示
- 对长了的文章进行分页显示!
- 使用 xsl 对 xml 文档进行动态排序,分页显示的扩展
- jsp+java bean+mysql数据库进行分页显示
- 对数据进行分页,显示到table中。
- 水晶报表进行页小计、固定行分页、分页中每页显示紧贴式页脚的方法
- 利用recordset组件中的一些属性进行分页显示.
- 使用MVCPager进行博客园首页列表数据的分页显示功能
- json一次取所有数据,然后在前后进行分页显示
- 面试题:如何对查询结果进行分页显示
- 用jsp进行数据分页显示的一个实现
- 用jsp进行数据分页显示的一个实现
- 文章,记录按内容分页显示,根据文章内容按字数进行分页
- 文章,记录按内容分页显示,根据文章内容按字数进行分页
- 一个查询数据库所有表的存储过程(允许按表名模糊查询一级按显示数量进行分页)
- 如何在WinForm中对DataGrid进行分页显示
- vb.net中对Repeater控件进行分页显示
- 如何在WinForm中对DataGrid进行分页显示(转)
- ExtJs4.1将服务器中的数据进行分页显示