TP5框架实现自定义分页样式的方法示例
这篇文章主要介绍了TP5框架实现自定义分页样式的方法,结合实例形式详细分析了TP5自定义分页样式相关类定义、样式设置、配置与使用技巧,需要的朋友可以参考下
本文实例讲述了TP5框架实现自定义分页样式的方法。分享给大家供大家参考,具体如下:
1. 在extend\目录下创建page目录,在page目录下创建Page.php文件,将以下代码放入文件中。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 | <?php namespace page; use think\Paginator; class Page extends Paginator { //首页 protected function home() { if ( $this ->currentPage() > 1) { return "<a href='" . $this ->url(1) . "' title='首页'>首页</a>" ; } else { return "<p>首页</p>" ; } } //上一页 protected function prev() { if ( $this ->currentPage() > 1) { return "<a href='" . $this ->url( $this ->currentPage - 1) . "' title='上一页'>上一页</a>" ; } else { return "<p>上一页</p>" ; } } //下一页 protected function next() { if ( $this ->hasMore) { return "<a href='" . $this ->url( $this ->currentPage + 1) . "' title='下一页'>下一页</a>" ; } else { return "<p>下一页</p>" ; } } //尾页 protected function last() { if ( $this ->hasMore) { return "<a href='" . $this ->url( $this ->lastPage) . "' title='尾页'>尾页</a>" ; } else { return "<p>尾页</p>" ; } } //统计信息 protected function info(){ return "<p class='pageRemark'>共<b>" . $this ->lastPage . "</b>页<b>" . $this ->total . "</b>条数据</p>" ; } /** * 页码按钮 * @return string */ protected function getLinks() { $block = [ 'first' => null, 'slider' => null, 'last' => null ]; $side = 3; $window = $side * 2; if ( $this ->lastPage < $window + 6) { $block [ 'first' ] = $this ->getUrlRange(1, $this ->lastPage); } elseif ( $this ->currentPage <= $window ) { $block [ 'first' ] = $this ->getUrlRange(1, $window + 2); $block [ 'last' ] = $this ->getUrlRange( $this ->lastPage - 1, $this ->lastPage); } elseif ( $this ->currentPage > ( $this ->lastPage - $window )) { $block [ 'first' ] = $this ->getUrlRange(1, 2); $block [ 'last' ] = $this ->getUrlRange( $this ->lastPage - ( $window + 2), $this ->lastPage); } else { $block [ 'first' ] = $this ->getUrlRange(1, 2); $block [ 'slider' ] = $this ->getUrlRange( $this ->currentPage - $side , $this ->currentPage + $side ); $block [ 'last' ] = $this ->getUrlRange( $this ->lastPage - 1, $this ->lastPage); } $html = '' ; if ( is_array ( $block [ 'first' ])) { $html .= $this ->getUrlLinks( $block [ 'first' ]); } if ( is_array ( $block [ 'slider' ])) { $html .= $this ->getDots(); $html .= $this ->getUrlLinks( $block [ 'slider' ]); } if ( is_array ( $block [ 'last' ])) { $html .= $this ->getDots(); $html .= $this ->getUrlLinks( $block [ 'last' ]); } return $html ; } /** * 渲染分页html * @return mixed */ public function render() { if ( $this ->hasPages()) { if ( $this ->simple) { return sprintf( '%s<div class="pagination">%s %s %s</div>' , $this ->css(), $this ->prev(), $this ->getLinks(), $this ->next() ); } else { return sprintf( '%s<div class="pagination">%s %s %s %s %s %s</div>' , $this ->css(), $this ->home(), $this ->prev(), $this ->getLinks(), $this ->next(), $this ->last(), $this ->info() ); } } } /** * 生成一个可点击的按钮 * * @param string $url * @param int $page * @return string */ protected function getAvailablePageWrapper( $url , $page ) { return '<a href="' . htmlentities( $url ) . '" rel="external nofollow" title="第"' . $page . '"页" >' . $page . '</a>' ; } /** * 生成一个禁用的按钮 * * @param string $text * @return string */ protected function getDisabledTextWrapper( $text ) { return '<p class="pageEllipsis">' . $text . '</p>' ; } /** * 生成一个激活的按钮 * * @param string $text * @return string */ protected function getActivePageWrapper( $text ) { return '<a href="" class=" rel="external nofollow" cur">' . $text . '</a>' ; } /** * 生成省略号按钮 * * @return string */ protected function getDots() { return $this ->getDisabledTextWrapper( '...' ); } /** * 批量生成页码按钮. * * @param array $urls * @return string */ protected function getUrlLinks( array $urls ) { $html = '' ; foreach ( $urls as $page => $url ) { $html .= $this ->getPageLinkWrapper( $url , $page ); } return $html ; } /** * 生成普通页码按钮 * * @param string $url * @param int $page * @return string */ protected function getPageLinkWrapper( $url , $page ) { if ( $page == $this ->currentPage()) { return $this ->getActivePageWrapper( $page ); } return $this ->getAvailablePageWrapper( $url , $page ); } /** * 分页样式 */ protected function css(){ return ' <style type= "text/css" > .pagination p{ margin:0; cursor:pointer } .pagination{ height:40px; padding:20px 0px; } .pagination a{ display:block; float:left; margin-right:10px; padding:2px 12px; height:24px; border:1px #cccccc solid; background:#fff; text-decoration:none; color:#808080; font-size:12px; line-height:24px; } .pagination a:hover{ color:#077ee3; background: white; border:1px #077ee3 solid; } .pagination a.cur{ border:none; background:#077ee3; color:#fff; } .pagination p{ float:left; padding:2px 12px; font-size:12px; height:24px; line-height:24px; color:#bbb; border:1px #ccc solid; background:#fcfcfc; margin-right:8px; } .pagination p.pageRemark{ border-style:none; background:none; margin-right:0px; padding:4px 0px; color:#666; } .pagination p.pageRemark b{ color:red; } .pagination p.pageEllipsis{ border-style:none; background:none; padding:4px 0px; color:#808080; } .dates li {font-size: 14px;margin:20px 0} .dates li span{float:right} </style>'; } } |
2. 修改 application\config.php 中的配置文件即可
1 2 3 4 5 6 | //分页配置 'paginate' => [ 'type' => 'page\Page' , //分页类 'var_page' => 'page' , 'list_rows' => 15, ], |
3. 分页样式为