zoukankan      html  css  js  c++  java
  • php ajax分页

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>php+ajax分页</title>
    </head>
    <style>
        .active{
            color: red;
        }
    </style>
    <body>
    
    <div id="box">
    
    {foreach $data['list'] $k $v}
        <p>{$v['id']}</p>
    {/foreach}
    </div>
    
    <hr>
    <div id="box2">
                <p>{$data['page']}</p>
    </div>
    
    </body>
    </html>
    
    
    <script src="/template/default/js/jquery.1.7.2.js"></script>
    <script>
    function a(page){
        $.ajax({
            type: "Post",
            url: '{HOST_NAME}comment/comment/ajaxPage',
            data: {'page':page, 'code': 1},
            dataType: "json",
            beforeSend: function () {
            },
            complete: function () {
            },
            success: function(data) {
                if (data) {
                    var str = "";
                    for(var i=0; i<data.length; i++){
                        str += "<p>"+data[i].id+"</p>";
                    }
                    $("#box").html('');
                    $("#box").append(str);
                    b(page);
                }
            }
        });
    }
    
    function b(page){
        $.ajax({
            type: "Post",
            url: '{HOST_NAME}comment/comment/ajaxPage',
            data: {'page':page,'code':2},
            dataType: "json",
            beforeSend: function () {
            },
            complete: function () {
            },
            success: function(data) {
                $("#box2").html('');
                $("#box2").append(data);
            }
        });
    }
    
    </script>
    

      实现方法:

    public function ajaxPageAction()
            {
                $total = M('member')->findCount();// 数据总条数
                Load::load_class('Mypage2',DIR_BF_ROOT.'classes',0);
                $biao = isset($_POST['page']) ? $_POST['page'] : 1;
                $pagesize = 5; //每页显示
                $page = ($biao -1)* $pagesize;
                $href = "/comment/comment/ajaxPage?page=";
                $p = new Page2($total, $pagesize, $biao, $pagesize, $href);
                $limit = "$page, $pagesize";
                $goods_all = M('member')->field('id')->limit($limit)->select(); //数据
                $data = array();
                $data['list'] = $goods_all;
                $data['page'] = $p->showPages(2);
    
                if(isPost() && $_POST['code'] == 1){ // 获取数据
                    echo json_encode($data['list']);exit();
                }else if(isPost() && $_POST['code'] == 2){ // 获取分页
                    echo json_encode($data['page']);exit();
                }else{
                    // 获取总条数
                    include $this->display('ajaxPage.html');
                }
    
            }
    

      需要用到的分页类,其实就是在普通的分页类中为每一个分页页码,增加了一个js点击方法,用来获取当前的页码id

    <?php
    /**
     * 分页类
     *
     * 调用方式:
     * $p=new Page(总页数,显示页数,当前页码,每页显示条数,[链接]);
     * print_r($p->getPages()); //生成一个页码数组(键为页码,值为链接)
     * echo $p->showPages(1);    //生成一个页码样式(可添加自定义样式)
     *
     * @author: 草根级
     * @Last Modified time: 2017-01-09 13:31
     */
    
    /*
    思路:
    给我一个 总页数,需要显示的页数,当前页,每页显示的条数,连接
    写一个方法 生成一个一维数组,键为页码 值为连接
    写一个方法 返回一个生成好样式的页码(并且可以根据自己需要添加样式)
    默认样式 共45条记录,每页显示10条,当前第1/4页 [首页] [上页] [1] [2] [3] .. [下页] [尾页]
    */
    class Page2{
        protected $count;       //总条数
        protected $showPages;   //需要显示的页数
        protected $countPages;  //总页数
        protected $currPage;    //当前页
        protected $subPages;    //每页显示条数
        protected $href;        //连接
        protected $page_arr=array();    //保存生成的页码 键页码 值为连接
    
        /**
         * __construct  构造函数(获取分页所需参数)
         * @param int $count     总条数
         * @param int $showPages 显示页数
         * @param int $currPage  当前页数
         * @param int $subPages  每页显示数量
         * @param string $href   连接(不设置则获取当前URL)
         */
        public function __construct($count,$showPages,$currPage,$subPages,$href=''){
            $this->count=$count;
            $this->showPages=$showPages;
            $this->currPage=$currPage;
            $this->subPages=$subPages;
    
            //如果链接没有设置则获取当前连接
    
            $this->href=$href;
            $this->construct_Pages();
        }
    
        /**
         * getPages 返回页码数组
         * @return array 一维数组 键为页码 值为链接
         */
        public function getPages(){
            return $this->page_arr;
        }
    
        /**
         * showPages 返回生成好的页码
         * @param  int $style 样式
         * @return string     生成好的页码
         */
        public function showPages($style=1){
            $func='pageStyle'.$style;
            return $this->$func();
        }
    
        /**
         * pageStyle1 分页样式(可参照这个添加自定义样式 例如pageStyle2())
         * 样式 共45条记录,每页显示10条,当前第1/4页 [首页] [上页] [1] [2] [3] .. [下页] [尾页]
         * @return string
         */
        protected function pageStyle1(){
            /* 构造普通模式的分页
            共4523条记录,每页显示10条,当前第1/453页 [首页] [上页] [1] [2] [3] .. [下页] [尾页]
            */
            $pageStr='共'.$this->count.'条记录,每页显示'.$this->subPages.'条';
            $pageStr.='当前第'.$this->currPage.'/'.$this->countPages.'页 ';
    
            $_GET['page'] = 1;
            $pageStr.='<span>[<a href="'.$this->href.''.$_GET['page'].'">首页</a>] </span>';
            //如果当前页不是第一页就显示上页
            if($this->currPage>1){
                $_GET['page'] = $this->currPage-1;
                $pageStr.='<span>[<a href="'.$this->href.''.$_GET['page'].'">上页</a>] </span>';
            }
    
            foreach ($this->page_arr as $k => $v) {
                $_GET['page'] = $k;
                $pageStr.='<span>[<a href="'.$v.'">'.$k.'</a>] </span>';
            }
    
            //如果当前页小于总页数就显示下一页
            if($this->currPage<$this->countPages){
                $_GET['page'] = $this->currPage+1;
                $pageStr.='<span>[<a href="'.$this->href.''.$_GET['page'].'">下页</a>] </span>';
            }
    
            $_GET['page'] = $this->countPages;
            $pageStr.='<span>[<a href="'.$this->href.''.$_GET['page'].'">尾页</a>] </span>';
    
            return $pageStr;
        }
    
        protected function pageStyle2(){
            /* 构造普通模式的分页
             [首页] [上页] [1] [2] [3] [下页] [尾页]
            */
            $pageStr = "";
    
            $_GET['page'] = 1;
    //        $pageStr.='<a href="'.$this->href.''.$_GET['page'].'">首页</a>';
            //如果当前页不是第一页就显示上页
            if($this->currPage>1){
                $_GET['page'] = $this->currPage-1;
                $pageStr.='<a href="javascript:;" class="prev_yc" onclick=a("'.$_GET['page'].'")>上页</a>';
            }
    
            foreach ($this->page_arr as $k => $v) {
                $_GET['page'] = $k;
                if($this->currPage == $k){ //如果是当前页面 设置选中样式
                    $pageStr.= "<a href='javascript:;' class='active' onclick=a(".$k.")>$k</a>";
                }else{
                    $pageStr.= "<a href='javascript:;' onclick=a(".$k.")>$k</a>";
    
                }
            }
    
            //如果当前页小于总页数就显示下一页
            if($this->currPage<$this->countPages){
                $_GET['page'] = $this->currPage+1;
                $pageStr.='<a href="javascript:;" class="next_yc" onclick=a("'.$_GET['page'].'")><i></i>下页</a>';
            }
    
            $_GET['page'] = $this->countPages;
    //        $pageStr.='<a href="'.$this->href.''.$_GET['page'].'">尾页</a>';
    
            return $pageStr;
        }
    
        protected function pageStyle3(){
            /* 构造普通模式的分页
             [1] [2] [3]
            */
            $pageStr = "";
    
            $_GET['page'] = 1;
            //如果当前页不是第一页就显示上页
    
            foreach ($this->page_arr as $k => $v) {
                $_GET['page'] = $k;
                $pageStr.='<span>[<a href="'.$v.'">'.$k.'</a>] </span>';
            }
    
            //如果当前页小于总页数就显示下一页
    
            return $pageStr;
        }
    
        /**
         * construct_Pages 生成页码数组
         * 键为页码,值为链接
         * $this->page_arr=Array(
         *                  [1] => index.php?page=1
         *                  [2] => index.php?page=2
         *                  [3] => index.php?page=3
         *                  ......)
         */
        protected function construct_Pages(){
            //计算总页数
            $this->countPages=ceil($this->count/$this->subPages);
            //根据当前页计算前后页数
            $leftPage_num=floor($this->showPages/2);
            $rightPage_num=$this->showPages-$leftPage_num;
    
            //左边显示数为当前页减左边该显示的数 例如总显示7页 当前页是5  左边最小为5-3  右边为5+3
            $left=$this->currPage-$leftPage_num;
            $left=max($left,1); //左边最小不能小于1
            $right=$left+$this->showPages-1; //左边加显示页数减1就是右边显示数
            $right=min($right,$this->countPages);  //右边最大不能大于总页数
            $left=max($right-$this->showPages+1,1); //确定右边再计算左边,必须二次计算
    
            for ($i=$left; $i <= $right; $i++) {
                $_GET['page'] = $i;
                $this->page_arr[$i]=$this->href.''.$_GET['page'];
            }
        }
    }
    

      

  • 相关阅读:
    列表
    CENTOS安装xwindow
    查看LINUX系统的配置
    LINUX开启SAMBA服务
    oracle linux 7 yum报错解决:COULD NOT RESOLVE HOST: YUM.ORACLE.COM
    ORACLE百分比分析函数RATIO_TO_REPORT() OVER()
    用matlab计算线性回归问题
    OL7.6上RPM方式安装Oracle 19c
    使用vnc远程操控Centos7.6
    OPATCH在线补丁
  • 原文地址:https://www.cnblogs.com/photo520/p/8652658.html
Copyright © 2011-2022 走看看