thinkPHP3.2实现分页自定义样式的方法讲解

thinkPHP3.2实现分页自定义样式的方法讲解

内容导读

收集整理的这篇技术教程文章主要介绍了thinkPHP3.2实现分页自定义样式的方法讲解,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含6051字,纯文字阅读大概需要9分钟

内容图文

这篇文章主要介绍了thinkPHP3.2实现分页自定义样式的方法,结合实例形式分析了thinkPHP3.2针对底层框架代码的修改与使用相关操作技巧,需要的朋友可以参考下

本文实例讲述了thinkPHP3.2实现分页自定义样式的方法。分享给大家供大家参考,具体如下:

下面是一个Tp3.2的自定义分页,这个方法也是在看过一个网友的博客之后受到启发这么写的。经过了一些修改,大家在看到代码之后也可以进行修改自定义样式;

主要的样式控制文件就是page.css,框架底层的分页类可以直接进行粘贴复制使用;

1. 框架底层的page.class.php 路径( EngineLibraryThink)

其实这个文件不需要过多修改,也可以直接使用官方的就行;下面是我现在用的,稍作了修改;

<?phpnamespace Think;class Page{
public $firstRow; // 起始行数
public $listRows; // 列表每页显示行数
public $parameter; // 分页跳转时要带的参数
public $totalRows; // 总行数
public $totalPages; // 分页总页面数
public $rollPage
= 11;// 分页栏每页显示的页数
public $lastSuffix = true; // 最后一页是否显示总页数
private $p

= 'p'; //分页参数名
private $url
 = ''; //当前链接URL
private $nowPage = 1;
// 分页显示定制
private $config = array(

'header' => '<span class="rows">共 %TOTAL_ROW% 条记录</span>',

'prev'
=> '<<',

'next'
=> '>>',

'first' => '1...',

'last'
=> '...%TOTAL_PAGE%',

'theme' => '%FIRST% %UP_PAGE% %LINK_PAGE% %DOWN_PAGE% %END%',
);
/**
 * 架构函数
 * @param array $totalRows 总的记录数
 * @param array $listRows 每页显示记录数
 * @param array $parameter 分页跳转的参数
 */
public function __construct($totalRows, $listRows=20, $parameter = array()) {

C('VAR_PAGE') && $this->p = C('VAR_PAGE'); //设置分页参数名称

/* 基础设置 */

$this->totalRows = $totalRows; //设置总记录数

$this->listRows
= $listRows; //设置每页显示行数

$this->parameter = empty($parameter) ? $_GET : $parameter;

$this->nowPage
= empty($_GET[$this->p]) ? 1 : intval($_GET[$this->p]);

$this->firstRow
= $this->listRows * ($this->nowPage - 1);
}
/**
 * 定制分页链接设置
 * @param string $name 设置名称
 * @param string $value 设置值
 */
public function setConfig($name,$value) {

if(isset($this->config[$name])) {


$this->config[$name] = $value;

}
}
/**
 * 生成链接URL
 * @param integer $page 页码
 * @return string
 */
private function url($page){

return str_replace(urlencode('[PAGE]'), $page, $this->url);
}
/**
 * 组装分页链接
 * @return string
 */
public function show() {

if(0 == $this->totalRows) return '';

/* 生成URL */

$this->parameter[$this->p] = '[PAGE]';

$this->url = U(ACTION_NAME, $this->parameter);

/* 计算分页信息 */

$this->totalPages = ceil($this->totalRows / $this->listRows); //总页数

if(!empty($this->totalPages) && $this->nowPage > $this->totalPages) {


$this->nowPage = $this->totalPages;

}

/* 计算分页零时变量 */

$now_cool_page
 = $this->rollPage/2;

$now_cool_page_ceil = ceil($now_cool_page);

$this->lastSuffix && $this->config['last'] = $this->totalPages;

//上一页

$up_row = $this->nowPage - 1;

$up_page = $up_row > 0 ? '<a class="prev" href="' . $this->url($up_row) . '" rel="external nofollow" >' . $this->config['prev'] . '</a>' : '';

//下一页

$down_row = $this->nowPage + 1;

$down_page = ($down_row <= $this->totalPages) ? '<a class="next" href="' . $this->url($down_row) . '" rel="external nofollow" >' . $this->config['next'] . '</a>' : '';

//第一页

$the_first = '';

if($this->totalPages > $this->rollPage && ($this->nowPage - $now_cool_page) >= 1){


$the_first = '<a class="first" href="' . $this->url(1) . '" rel="external nofollow" >' . $this->config['first'] . '</a>';

}

//最后一页

$the_end = '';

if($this->totalPages > $this->rollPage && ($this->nowPage + $now_cool_page) < $this->totalPages){


$the_end = '<a class="end" href="' . $this->url($this->totalPages) . '" rel="external nofollow" >' . $this->config['last'] . '</a>';

}

//数字连接

$link_page = "";

for($i = 1; $i <= $this->rollPage; $i++){


if(($this->nowPage - $now_cool_page) <= 0 ){



$page = $i;


}elseif(($this->nowPage + $now_cool_page - 1) >= $this->totalPages){



$page = $this->totalPages - $this->rollPage + $i;


}else{



$page = $this->nowPage - $now_cool_page_ceil + $i;


}


if($page > 0 && $page != $this->nowPage){



if($page <= $this->totalPages){




$link_page .= '<a class="num" href="' . $this->url($page) . '" rel="external nofollow" >' . $page . '</a>';



}else{




break;



}


}else{



if($page > 0 && $this->totalPages != 1){




$link_page .= '<span class="current">' . $page . '</span>';



}


}

}

//替换分页内容

$page_str = str_replace(


array('%HEADER%', '%NOW_PAGE%', '%UP_PAGE%', '%DOWN_PAGE%', '%FIRST%', '%LINK_PAGE%', '%END%', '%TOTAL_ROW%', '%TOTAL_PAGE%'),


array($this->config['header'], $this->nowPage, $up_page, $down_page, $the_first, $link_page, $the_end, $this->totalRows, $this->totalPages),


$this->config['theme']);

return "<p>{$page_str}</p>";
}}

2. 控制器,随便写个demo。

public function index(){

$obj=M("news");

$count = $obj->where('status=1 and classID=74 ')->count();// 查询满足要求的总记录数

$limit = 10;

$Page = new ThinkPage($count,$limit);// 实例化分页类 传入总记录数和每页显示的记录数(25)

$show

= $Page->show();// 分页显示
输出 $list = $obj->where('status=1 and classID=74 ')->order('writetime desc')->limit($Page->firstRow.','.$Page->listRows)->select(); $firstlist = $obj->where('status=1 and classID=74 and Indexfirst=1')->order('writetime desc')->limit(4)->select(); $this->assign('firstlist',$firstlist); $this->assign('page',$show);// 赋值分页输出 $this->assign('list',$list); $this->display();}

3. 接下来是View层,样式控制。page.css文件

.b-page { background: #fff; box-shadow: 0px 1px 2px 0px #E2E2E2;}.page { width: 100%; background: #FFF; text-align: center; overflow: hidden; font-size:14px; margin-top:50px;}.page .first,.page .prev,.page .current,.page .num,.page .current,.page .next,.page .end { padding: 8px 16px; margin: 0px 5px; display: inline-block; color: #144970; border: 1px solid #F2F2F2; border-radius: 5px;}.page .first:hover,.page .prev:hover,.page .current:hover,.page .num:hover,.page .current:hover,.page .next:hover,.page .end:hover { text-decoration: none; background: #F8F5F5;}.page .current { background-color: #144970; color: #FFF; border-radius: 5px;}.page .current:hover { text-decoration: none; background: #144970;}.page .not-allowed { cursor: not-allowed;}

您可能感兴趣的文章:

Laravel框架+Blob实现的多图上传功能示例解析

Swoole 1.10.0新版本发布,增加了多项新特性解析

PHP实现顺时针打印矩阵(螺旋矩阵)的方法示例讲解

以上就是thinkPHP3.2实现分页自定义样式的方法讲解的详细内容,更多请关注Gxl网其它相关文章!

内容总结

以上是为您收集整理的thinkPHP3.2实现分页自定义样式的方法讲解全部内容,希望文章能够帮你解决thinkPHP3.2实现分页自定义样式的方法讲解所遇到的程序开发问题。 如果觉得技术教程内容还不错,欢迎将网站推荐给程序员好友。

内容备注

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。


本文关键词:

联系我们

在线咨询:点击这里给我发消息

邮件:w420220301@qq.com