本文实例讲述了yii分页组件用法。分享给大家供大家参考,具体如下:
该案例使用时,分页类在yii框架中以组件的形式存在于components中。
action代码如下:
public function actionIndex(){ $user=User::model(); //分页的使用 $count=$user->count(); //获取总页数 $pagesize=3; //每一页显示的记录条数 $page=new Page($count,$pagesize); $sql=\"select * from {{user}} $page->limit\"; $info=$user->findAllBySql($sql); $show_page=$page->fpage(); $this->renderPartial(\"index\",array(\"info\"=>$info,\'show_page\'=>$show_page)); }
在view页面,遍历info即可获取信息,输出show_page即可显示分页列表等信息。
现附上page.php代码如下:
<?php /** * 分页类,以组件形式存在于componnets文件中 */ class Page { private $total; //数据表中总记录数 private $listRows; //每页显示行数 private $limit; private $uri; private $pageNum; //页数 private $config=array(\'header\'=>\"个记录\", \"prev\"=>\"上一页\", \"next\"=>\"下一页\", \"first\"=>\"首 页\", \"last\"=>\"尾 页\"); private $listNum=8; /* * $total * $listRows */ public function __construct($total, $listRows=10, $pa=\"\"){ $this->total=$total; $this->listRows=$listRows; $this->uri=$this->getUri($pa); $this->page=!empty($_GET[\"page\"]) ? $_GET[\"page\"] : 1; $this->pageNum=ceil($this->total/$this->listRows); $this->limit=$this->setLimit(); } private function setLimit(){ return \"Limit \".($this->page-1)*$this->listRows.\", {$this->listRows}\"; } private function getUri($pa){ $url=$_SERVER[\"REQUEST_URI\"].(strpos($_SERVER[\"REQUEST_URI\"], \'?\')?\'\':\"?\").$pa; $parse=parse_url($url); if(isset($parse[\"query\"])){ parse_str($parse[\'query\'],$params); unset($params[\"page\"]); $url=$parse[\'path\'].\'?\'.http_build_query($params); } return $url; } function __get($args){ if($args==\"limit\") return $this->limit; else return null; } private function start(){ if($this->total==0) return 0; else return ($this->page-1)*$this->listRows+1; } private function end(){ return min($this->page*$this->listRows,$this->total); } private function first(){ $html=\'\'; if($this->page==1) $html.=\'\'; else $html.=\" <a href=\'{$this->uri}&page=1\'>{$this->config[\"first\"]}</a> \"; return $html; } private function prev(){ $html=\'\'; if($this->page==1) $html.=\'\'; else $html.=\" <a href=\'{$this->uri}&page=\".($this->page-1).\"\'>{$this->config[\"prev\"]}</a> \"; return $html; } private function pageList(){ $linkPage=\"\"; $inum=floor($this->listNum/2); for($i=$inum; $i>=1; $i--){ $page=$this->page-$i; if($page<1) continue; $linkPage.=\" <a href=\'{$this->uri}&page={$page}\'>{$page}</a> \"; } $linkPage.=\" {$this->page} \"; for($i=1; $i<=$inum; $i++){ $page=$this->page+$i; if($page<=$this->pageNum) $linkPage.=\" <a href=\'{$this->uri}&page={$page}\'>{$page}</a> \"; else break; } return $linkPage; } private function next(){ $html=\'\'; if($this->page==$this->pageNum) $html.=\'\'; else $html.=\" <a href=\'{$this->uri}&page=\".($this->page+1).\"\'>{$this->config[\"next\"]}</a> \"; return $html; } private function last(){ $html=\'\'; if($this->page==$this->pageNum) $html.=\'\'; else $html.=\" <a href=\'{$this->uri}&page=\".($this->pageNum).\"\'>{$this->config[\"last\"]}</a> \"; return $html; } private function goPage(){ return \' <input type=\"text\" onkeydown=\"javascript:if(event.keyCode==13){var page=(this.value>\'.$this->pageNum.\')?\'.$this->pageNum.\':this.value;location=\\\'\'.$this->uri.\'&page=\\\'+page+\\\'\\\'}\" value=\"\'.$this->page.\'\" style=\"width:25px\"><input type=\"button\" value=\"GO\" onclick=\"javascript:var page=(this.previousSibling.value>\'.$this->pageNum.\')?\'.$this->pageNum.\':this.previousSibling.value;location=\\\'\'.$this->uri.\'&page=\\\'+page+\\\'\\\'\"> \'; } function fpage($display=array(0,1,2,3,4,5,6,7,8)){ $html[0]=\" 共有<b>{$this->total}</b>{$this->config[\"header\"]} \"; $html[1]=\" 每页显示<b>\".($this->end()-$this->start()+1).\"</b>条,本页<b>{$this->start()}-{$this->end()}</b>条 \"; $html[2]=\" <b>{$this->page}/{$this->pageNum}</b>页 \"; $html[3]=$this->first(); $html[4]=$this->prev(); $html[5]=$this->pageList(); $html[6]=$this->next(); $html[7]=$this->last(); $html[8]=$this->goPage(); $fpage=\'\'; foreach($display as $index){ $fpage.=$html[$index]; } return $fpage; } }
希望本文所述对大家基于yii框架的PHP程序设计有所帮助。
本文地址:https://www.stayed.cn/item/5101
转载请注明出处。
本站部分内容来源于网络,如侵犯到您的权益,请 联系我