ajax无刷新分页类

<?php 
class Page {

 

// 分页栏每页显示的页数

public $rollPage = 10;

// 页数跳转时要带的参数

public $parameter;

// 默认列表每页显示行数

public $listRows = 20;

// 起始行数

public $firstRow;

// 分页总页面数

protected $totalPages;

// 总行数

protected $totalRows;

// 当前页数

protected $nowPage;

// 分页的栏的总页数

protected $coolPages;

// 分页显示定制

protected $config = array(‘header‘ => ‘条记录‘, ‘prev‘ => ‘上一页‘, ‘next‘ => ‘下一页‘, ‘first‘ => ‘首页‘, ‘last‘ => ‘尾页‘, ‘theme‘ => ‘ %totalRow% %header% %nowPage%/%totalPage% 页 %upPage%  %first%  %prePage%  %linkPage% %downPage% %nextPage% %end% %ajax%‘);

// 默认分页变量名

protected $varPage;

//分页外层div的id

protected $pagesId;

//分页内容替换目标ID

protected $target;

 

/**

+----------------------------------------------------------

* 架构函数

+----------------------------------------------------------

* @access public

+----------------------------------------------------------

* @param array $totalRows  总的记录数

* @param array $listRows  每页显示记录数

* @param array $parameter  分页跳转的参数

+----------------------------------------------------------

*/

public function __construct($totalRows, $listRows = ‘‘, $parameter = ‘‘,$target=‘‘,$pagesId=‘‘) {

$this->totalRows = $totalRows;

$this->parameter = $parameter;

$this->target = $target;

$this->pagesId = $pagesId;

$this->varPage = C(‘VAR_PAGE‘) ? C(‘VAR_PAGE‘) : ‘p‘;

if (!empty($listRows)) {

$this->listRows = intval($listRows);

}

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

$this->coolPages = ceil($this->totalPages / $this->rollPage);

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

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

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

}

$this->firstRow = $this->listRows * ($this->nowPage - 1);

}

 

public function setConfig($name, $value) {

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

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

}

}

 

/**

+----------------------------------------------------------

* 分页显示输出

+----------------------------------------------------------

* @access public

+----------------------------------------------------------

*/

public function show() {

if (0 == $this->totalRows)

return ‘‘;

$p = $this->varPage;

$nowCoolPage = ceil($this->nowPage / $this->rollPage);

$url = $_SERVER[‘REQUEST_URI‘] . (strpos($_SERVER[‘REQUEST_URI‘], ‘?‘) ? ‘‘ : "?") . $this->parameter;

$parse = parse_url($url);

if (isset($parse[‘query‘])) {

parse_str($parse[‘query‘], $params);

unset($params[$p]);

$url = $parse[‘path‘] . ‘?‘ . http_build_query($params);

}

//上下翻页字符串

$upRow = $this->nowPage - 1;

$downRow = $this->nowPage + 1;

if ($upRow > 0) {

$upPage = "<a href=‘" . $url . "&" . $p . "=$upRow‘>" . $this->config[‘prev‘] . "</a>";

} else {

$upPage = "";

}

 

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

$downPage = "<a href=‘" . $url . "&" . $p . "=$downRow‘>" . $this->config[‘next‘] . "</a>";

} else {

$downPage = "";

}

// << < > >>

if ($nowCoolPage == 1) {

$theFirst = "";

$prePage = "";

} else {

$preRow = $this->nowPage - $this->rollPage;

$prePage = "<a href=‘" . $url . "&" . $p . "=$preRow‘ >上" . $this->rollPage . "页</a>";

$theFirst = "<a href=‘" . $url . "&" . $p . "=1‘ >" . $this->config[‘first‘] . "</a>";

}

if ($nowCoolPage == $this->coolPages) {

$nextPage = "";

$theEnd = "";

} else {

$nextRow = $this->nowPage + $this->rollPage;

$theEndRow = $this->totalPages;

$nextPage = "<a href=‘" . $url . "&" . $p . "=$nextRow‘ >下" . $this->rollPage . "页</a>";

$theEnd = "<a href=‘" . $url . "&" . $p . "=$theEndRow‘ >" . $this->config[‘last‘] . "</a>";

}

// 1 2 3 4 5

$linkPage = "";

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

$page = ($nowCoolPage - 1) * $this->rollPage + $i;

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

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

$linkPage .= "&nbsp;<a href=‘" . $url . "&" . $p . "=$page‘>&nbsp;" . $page . "&nbsp;</a>";

} else {

break;

}

} else {

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

$linkPage .= "&nbsp;<span class=‘current‘>" . $page . "</span>";

}

}

}

//<script>jquery分页</script>

$ajax = ‘‘;

if($this->target){

$ajax = <<<eco

<script>

jQuery(function($) {

$(‘#{$this->pagesId} a‘).click(function(){

$.ajax({

url: $(this).attr(‘href‘),

dataType: "html",

type: "POST",

cache: false,

success: function(html){

$("#{$this->target}").html(html);

}

});

return false;

});

});

</script>

eco;

}

$pageStr = str_replace(

array(

‘%header%‘,

‘%nowPage%‘,

‘%totalRow%‘,

‘%totalPage%‘,

‘%upPage%‘,

‘%downPage%‘,

‘%first%‘,

‘%prePage%‘,

‘%linkPage%‘,

‘%nextPage%‘,

‘%end%‘,

‘%ajax%‘

),

array(

$this->config[‘header‘],

$this->nowPage,

$this->totalRows,

$this->totalPages,

$upPage, $downPage,

$theFirst, $prePage,

$linkPage, $nextPage,

$theEnd,

$ajax

),

$this->config[‘theme‘]

);

return $pageStr;

}

}

调用方法:在tp中:

public function ajaxPage(){
        
        $tz=M(‘MoneyLog‘);
        import(‘ORG.Util.ajaxpage‘);
        $count = $tz->count();
         $page = new Page($count,10,‘type=1‘,‘ajax_div‘,‘ajax_page_div‘);
         
  
        $data = $tz->limit($page->firstRow, $page->listRows)->select();
        $pagestr =  $page->show();
        $this->assign(‘list‘,$data);
        $this->assign(‘show‘,$pagestr);
        if(IS_AJAX){
           exit($this->fetch(‘list‘));
        }
        $this->display(‘list‘);
        
    }

静态页面:

<script type="text/javascript" src="/Public/shouye/js/jquery-1.7.1.min.js"></script>
<div id="ajax_div">
<table>
    <tr>
        <td>性别</td><td>年龄</td><td>单位</td>
    </tr>
    <?php foreach($list as $v){ ?>
        <tr>
        <td><?php echo $v[‘total_money‘]; ?></td>
        <td><?php echo $v[‘time‘]; ?></td>
         <td><?php echo $v[‘ip‘]; ?></td>
         </tr>
         <?php } ?>

</table>
    <div><div id="ajax_page_div">{$show}</div></div>
</div>
<script>

jQuery(function($) {

$(‘#ajax_page_div a‘).click(function(){

$.ajax({

url: $(this).attr(‘href‘),

dataType: "html",

type: "POST",
data:‘zhangsan=‘+‘lisi‘,

cache: false,

success: function(html){

$("#ajax_div").html(html);

}

});

return false;

});

});

</script>
时间: 2024-10-18 22:09:24

ajax无刷新分页类的相关文章

Ajax无刷新分页

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <title></title> <sc

ThinkPhp 3.2 ajax无刷新分页(未完全改完,临时凑合着用)

临时更改后的page类(很多地方没修改...因为笔者PHP没学好..)如下: <?phpnamespace Fenye\libs; /**  file: page.class.php   完美分页类 Page  */ class Page {  private $total;          //数据表中总记录数  private $listRows;       //每页显示行数  private $limit;          //SQL语句使用limit从句,限制获取记录个数  pri

jquery+jquery.pagination+php+ajax 无刷新分页

<!DOCTYPE html> <html ><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>预约列表</title> <link rel="stylesheet" href="./static/pagination.css"> &

SUI分页组件和avalon搞定ajax无刷新分页

<div ms-controller="main"> <h2 class="pagination-centered">{{ title }}</h2> <form method="get" action="" class="sui-form" style="margin-bottom:5px;"> 重量:<input class=&q

TinkPHP_无刷新分页_未带搜索条件

1)前台显示模板: <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <title>Ajax 实现无刷新页面</title> <meta http-equiv="Content-Type" conte

在Thinkphp中使用AJAX实现无刷新分页

在Thinkphp目录的Lib\ORG\Util\目录里新建AjaxPage.class.php,写入一下内容: <?php // +---------------------------------------------------------------------- // | ThinkPHP [ WE CAN DO IT JUST THINK IT ] // +---------------------------------------------------------------

Ajax实现无刷新分页

注:本文中使用到的一些类库在前面文章都能找到源代码,我会在文中指明链接所在,为了缩短文章篇幅,由此带来的阅读不便,敬请谅解. 本文讲解 Ajax 实现无刷新分页.实现原理.代码展示.代码下载. 这里需要说明一些知识: 1.Ajax 无刷新页面的好处:提供良好的客户体验,通过 Ajax 在后台从数据库中取得数据并展示,取缔了等待加载页面而出现的空白状态: 2.那么,Ajax 无刷新页面是运行在动态页面(.PHP)?还是静态页面(.html/.htm/.shtml)?答案是:静态页面: 3.实现原理

Ajax 实现无刷新分页

Ajax 实现无刷新分页

smarty+php+ajax 简单无刷新分页

简介 分页,无非就是从数据库中获得我们想查询的数据,再加以处理即可! ① 确定数据总数($count) ② 每页显示数据条数($pageSize) ③ 分多少页($pageCount) ④ 上一页($pagePrev) ⑤ 下一页($pageNext) ⑥ 判断越界问题 ⑦ 偏移量($offset) ⑧ sql语句($sql = "select * from goods limit $offset,$pageSize";) 简单归简单,我们还得考虑实际的应用.例如:如果你正在土豆网看&