-
- /**
- * TODO 基本ページングと同じコードのカプセル化により、フロントエンド コードが少なくなります
- * @param $m モデル、参照によって渡されます
- * @param $where クエリ条件
- * @param int $pagesize ページごとのクエリ数
- * @return ThinkPage
- */
- function getpage(&$m,$where,$pagesize=10){
- $m1=clone $m;//モデルのシャローコピー
- $count = $m ->where($where)->count();//連続操作後、結合などの操作はリセットされます
- $m=$m1;//一定の連続操作を維持するために、Aモデルを浅くコピーします
- $p=new ThinkPage($count,$pagesize);
- $p->lastSuffix=false;
- $p->setConfig('header','
- 合計 ページあたりのレコード数%LIST_ROW% TOTAL_PAGE%ページ
');
- $p->setConfig('prev', '前のページ');
- $p->setConfig('次','次のページ');
- $p->setConfig('最後の','最後のページ');
- $p->setConfig( 'first','first page');
- $p->setConfig('theme' ,'%FIRST% %UP_PAGE% %LINK_PAGE% %DOWN_PAGE% %END% %HEADER%');
- $p->パラメータ=I('get.');
- $m->limit($p- >firstRow,$p->listRows);
- return $p;
- }
-
コードをコピー
getpageメソッドは、TP フレームワークの Application/Common/Common/function.php に配置できます。このドキュメントには、どこでも呼び出すことができるいくつかの共通メソッド (コントローラー ファイル、ビュー ファイルなど) を特別に配置できます。
2. ページングメソッドを呼び出す
-
- $m=M('products');
- $p=getpage($m,$where,10);
- $list=$m->field(true)->where($ where)->order('id desc')->select();
- $this->>list=$list;
- $this->page=$p->show();
- これはコードを表示
-
コードをコピー
3.
-
- .pagination ul {
- display: inline-block;
- margin-bottom: 0;
- margin-left: 0;
- -webkit-border-radius: 3px;
- -moz-border-radius: 3px ;
- border-radius: 3px;
- -webkit-box-shadow: 0 1px 2px rgba(0,0,0,0.05);
- -moz-box-shadow: 0 1px 2px rgba(0,0,0,0.05) ) );
- box-shadow: 0 1px 2px rgba(0,0,0,0.05);
- }
- .pagination ul li {
- 表示: インライン;
- }
- .pagination ul li.rows {
- line-height: 30px ;
- padding-left: 5px;
- }
- .pagination ul li.rows b{color: #f00}
- .pagination ul li a, .pagination ul li spa {
- float: left;
- padding: 4px 12px;
- line-height: 20px;
- text-decoration: none;
- background-color: #fff;
- background: url('../images/bottom_bg.png') 0px 0px;
- border: 1pxソリッド #d3dbde;
- / * border-left-width: 0;*/
- margin-left: 2px;
- color: #08c;
- }
- .pagination ul li a:hover{
- color: red;
- background: #0088cc;
- }
- 。 pagination ul li.first-child a, .pagination ul li.first-child span {
- border-left-width: 1px;
- -webkit-border-bottom-left-radius: 3px;
- border-bottom-left-radius : 3px;
- -webkit-border-top-left-radius: 3px;
- border-top-left-radius: 3px;
- -moz-border-radius-bottomleft: 3px;
- -moz-border-radius-topleft: 3px ;
- }
- .pagination ul .disabled span、.pagination ul .disabled a、.pagination ul .disabled a:hover {
- color: #999;
- cursor:default;
- background-color:transparent;
- }
- 。 pagination ul .active a, .pagination ul .active spag {
- color: #999;
- cursor:default;
- }
- .pagination ul li a:hover, .pagination ul .active a, .pagination ul .active spa {
- 背景 -色: #f0c040;
- }
- .pagination ul li.last-child a, .pagination ul li.last-child スパン {
- -webkit-border-top-right-radius: 3px;
- border-top-right - 半径: 3px;
- -webkit-border-bottom-right-radius: 3px;
- border-bottom-right-radius: 3px;
- -moz-border-radius-topright: 3px;
- -moz-border-radius- bottomright : 3px;
- }
- .pagination ul li.current a{color: #f00;font-weight:大胆; 背景: #ddd}
コードをコピー
|