热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

THINKPHP3ajax无刷新分页类及实例

最近在网上看见很多关于thinkphpajax无刷新分页的实例及说明都没有办法很容易的进行,所以我现在进行讲解和分析,这里已THINKPHP3.0开始讲解,首先需要一个ajax的分页类,找到ThinkPHP\Extend\Library\ORG

最近在网上看见很多关于thinkphp ajax无刷新分页的实例及说明都没有办法很容易的进行,所以我现在进行讲解和分析,这里已THINKPHP3.0 开始讲解

首先需要一个ajax的分页类

找到ThinkPHP\Extend\Library\ORG\Util 目录下的Page.class.php

复制一个Page.class.php 更改名字为AjaxPage.class.php 让这2个文件处与同一目录:

  1. // +---------------------------------------------------------------------- 
  2. // | ThinkPHP [ WE CAN DO IT JUST THINK IT ] 
  3. // +---------------------------------------------------------------------- 
  4. // | Copyright (c) 2009 http://thinkphp.cn All rights reserved. 
  5. // +---------------------------------------------------------------------- 
  6. // | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 ) 
  7. // +---------------------------------------------------------------------- 
  8. // | Author: liu21st  
  9. // +---------------------------------------------------------------------- 
  10. // $Id: Page.class.php 2712 2012-02-06 10:12:49Z liu21st $ 
  11. class AjaxPage { 
  12.     // 分页栏每页显示的页数 
  13.     public $rollPage = 5; 
  14.     // 页数跳转时要带的参数 
  15.     public $parameter  ; 
  16.     // 默认列表每页显示行数 
  17.     public $listRows = 20; 
  18.     // 起始行数 
  19.     public $firstRow ; 
  20.     // 分页总页面数 
  21.     protected $totalPages  ; 
  22.     // 总行数 
  23.     protected $totalRows  ; 
  24.     // 当前页数 
  25.     protected $nowPage    ; 
  26.     // 分页的栏的总页数 
  27.     protected $coolPages   ; 
  28.     // 分页显示定制 
  29.     protected $config  = array('header'=>'条记录','prev'=>'上一页','next'=>'下一页','first'=>'第一页','last'=>'最后一页','theme'=>' %totalRow% %header% %nowPage%/%totalPage% 页 %upPage% %downPage% %first%  %prePage%  %linkPage%  %nextPage% %end%'); 
  30.     // 默认分页变量名 
  31.     protected $varPage
  32.  
  33.     public function __construct($totalRows,$listRows='',$ajax_func,$parameter='') { 
  34.         $this->totalRows = $totalRows
  35.         $this->ajax_func = $ajax_func
  36.         $this->parameter = $parameter
  37.         $this->varPage = C('VAR_PAGE') ? C('VAR_PAGE') : 'p' ; 
  38.         if(!emptyempty($listRows)) { 
  39.             $this->listRows = intval($listRows); 
  40.         } 
  41.         $this->totalPages = ceil($this->totalRows/$this->listRows);     //总页数 
  42.         $this->coolPages  = ceil($this->totalPages/$this->rollPage); 
  43.         $this->nowPage  = !emptyempty($_GET[$this->varPage])?intval($_GET[$this->varPage]):1; 
  44.         if(!emptyempty($this->totalPages) && $this->nowPage>$this->totalPages) { 
  45.             $this->nowPage = $this->totalPages; 
  46.         } 
  47.         $this->firstRow = $this->listRows*($this->nowPage-1); 
  48.     } 
  49. public function setConfig($name,$value) { 
  50.         if(isset($this->config[$name])) { 
  51.             $this->config[$name]    =   $value
  52.         } 
  53.     } 
  54.  
  55.     public function show() { 
  56.         if(0 == $this->totalRows) return ''
  57.         $p = $this->varPage; 
  58.         $nowCoolPage      = ceil($this->nowPage/$this->rollPage); 
  59.         $url  =  $_SERVER['REQUEST_URI'].(strpos($_SERVER['REQUEST_URI'],'?')?'':"?").$this->parameter; 
  60.         $parse = parse_url($url); 
  61.         if(isset($parse['query'])) { 
  62.             parse_str($parse['query'],$params); 
  63.             unset($params[$p]); 
  64.             $url   =  $parse['path'].'?'.http_build_query($params); 
  65.         } 
  66.         //上下翻页字符串 
  67.         $upRow   = $this->nowPage-1; 
  68.         $downRow = $this->nowPage+1; 
  69.         if ($upRow>0){ 
  70.             $upPage=".$this->ajax_func."(".$upRow.")'>".$this->config['prev'].""
  71.         }else
  72.             $upPage=""
  73.         } 
  74. if ($downRow <= $this->totalPages){ 
  75.             $downPage=".$this->ajax_func."(".$downRow.")&#39;>".$this->config[&#39;next&#39;].""
  76.         }else
  77.             $downPage=""
  78.         } 
  79.         // << < > >> 
  80.         if($nowCoolPage == 1){ 
  81.             $theFirst = ""
  82.             $prePage = ""
  83.         }else
  84.             $preRow =  $this->nowPage-$this->rollPage; 
  85.             $prePage = ".$this->ajax_func."(".$preRow.")&#39;>上".$this->rollPage."页"
  86.             $theFirst = ".$this->ajax_func."(1)&#39; >".$this->config[&#39;first&#39;].""
  87.         } 
  88.         if($nowCoolPage == $this->coolPages){ 
  89.             $nextPage = ""
  90.             $theEnd=""
  91.         }else
  92.             $nextRow = $this->nowPage+$this->rollPage; 
  93.             $theEndRow = $this->totalPages; 
  94.             $nextPage = ".$this->ajax_func."(".$nextRow.")&#39; >下".$this->rollPage."页"
  95.             $theEnd = ".$this->ajax_func."(".$theEndRow.")&#39; >".$this->config[&#39;last&#39;].""
  96.         } 
  97.         // 1 2 3 4 5 
  98.         $linkPage = ""
  99.         for($i=1;$i<=$this->rollPage;$i++){ 
  100.             $page=($nowCoolPage-1)*$this->rollPage+$i
  101.             if($page!=$this->nowPage){ 
  102.                 if($page<=$this->totalPages){ 
  103.                    $linkPage .= .$this->ajax_func."(".$page.")&#39;> ".$page." "
  104.                 }else
  105.                     break
  106.                 } 
  107.             }else
  108.                 if($this->totalPages != 1){ 
  109.                     $linkPage .= ".$page.""
  110.                 } 
  111.             } 
  112.         } 
  113.         $pageStr  =  str_replace
  114.             array(&#39;%header%&#39;,&#39;%nowPage%&#39;,&#39;%totalRow%&#39;,&#39;%totalPage%&#39;,&#39;%upPage%&#39;,&#39;%downPage%&#39;,&#39;%first%&#39;,&#39;%prePage%&#39;,&#39;%linkPage%&#39;,&#39;%nextPage%&#39;,&#39;%end%&#39;), 
  115.             array($this->config[&#39;header&#39;],$this->nowPage,$this->totalRows,$this->totalPages,$upPage,$downPage,$theFirst,$prePage,$linkPage,$nextPage,$theEnd),$this->config[&#39;theme&#39;]); 
  116.         return $pageStr
  117.     } 
  118. ?> 

以上是我自己修改过的AjaxPage类

然后就要写控制器(Action):

  1. public function test(){ 
  2.   import("ORG.Util.AjaxPage");// 导入分页类  注意导入的是自己写的AjaxPage类 
  3.    
  4.   $credit = M(&#39;test&#39;); 
  5.    
  6.   $count = $credit->count(); //计算记录数 
  7.         $limitRows = 15; // 设置每页记录数 
  8.         
  9.         $p = new AjaxPage($count$limitRows,"test"); //第三个参数是你需要调用换页的ajax函数名 
  10.         $limit_value = $p->firstRow . "," . $p->listRows; 
  11.         
  12.         $data = $credit->order(&#39;id desc&#39;)->limit($limit_value)->select(); // 查询数据 
  13.         $page = $p->show(); // 产生分页信息,AJAX的连接在此处生成 
  14.     $this->assign(&#39;list&#39;,$data); 
  15.         $this->assign(&#39;page&#39;,$page); 
  16.         $this->display(); 
  17.  } 

这里没有进行Ajax的返回,如果需要就要自己修改AjaxPage类了哈,我觉得这样方便,就没有修改.

tpl页面重要部分:

  1. <div id=&#39;test&#39;>   //这里的test 和下面js中的test要一致 
  2. <volist id=&#39;list&#39; name=&#39;list&#39;>   //内容输出 
  3.    {$list.id}{$list.test} 
  4. volist> 
  5. {$page}  //分页输出 
  6. div> 

javascrip编写,调用了jquery 框架:

  1. function test(id){    //test函数名 一定要和action中的第三个参数一致上面有 
  2.  var id = id; 
  3.         $.get(&#39;Test/test&#39;, {&#39;p&#39;:id}, function(data){  //用get方法发送信息到TestAction中的test方法 
  4.      $("#test").replaceWith(""+data+"
"); //test一定要和tpl中的一致 
  •     }); 
  •  } 

  • 推荐阅读
    • 本文探讨了2019年前端技术的发展趋势,包括工具化、配置化和泛前端化等方面,并提供了详细的学习路线和职业规划建议。 ... [详细]
    • 一个登陆界面
      预览截图html部分123456789101112用户登入1314邮箱名称邮箱为空15密码密码为空16登 ... [详细]
    • 本文深入探讨了JavaScript中实现继承的四种常见方法,包括原型链继承、构造函数继承、组合继承和寄生组合继承。对于正在学习或从事Web前端开发的技术人员来说,理解这些继承模式对于提高代码质量和维护性至关重要。 ... [详细]
    • 本文将详细介绍如何在ThinkPHP6框架中实现多数据库的部署,包括读写分离的策略,以及如何通过负载均衡和MySQL同步技术优化数据库性能。 ... [详细]
    • 本文详细介绍了如何使用PHP检测AJAX请求,通过分析预定义服务器变量来判断请求是否来自XMLHttpRequest。此方法简单实用,适用于各种Web开发场景。 ... [详细]
    • 本文详细介绍了中央电视台电影频道的节目预告,并通过专业工具分析了其加载方式,确保用户能够获取最准确的电视节目信息。 ... [详细]
    • 本文介绍了多个关于JavaScript的书籍资源、实用工具和编程实例,涵盖从入门到进阶的各个阶段,帮助读者全面提升JavaScript编程能力。 ... [详细]
    • 本文介绍了一段使用jQuery实现的用户注册页面表单验证代码,适用于前端开发人员学习和参考。该示例结合了HTML、CSS和JavaScript,确保用户输入的数据格式正确。 ... [详细]
    • 探讨了如何解决Ajax请求响应时间过长的问题。本文分析了一个从服务器获取少量数据的Ajax请求,尽管服务器已经对JSON响应进行了缓存,但实际响应时间仍然不稳定。 ... [详细]
    • 在PHP后端开发中遇到一个难题:通过第三方类文件发送短信功能返回的JSON字符串无法解析。本文将探讨可能的原因并提供解决方案。 ... [详细]
    • 优化网页加载速度:JavaScript 实现图片延迟加载
      本文介绍如何使用 JavaScript 实现图片延迟加载,从而显著提升网页的加载速度和用户体验。 ... [详细]
    • 本文详细介绍了如何使用 HTML 和 CSS 对文件上传按钮进行样式美化,使用户界面更加友好和美观。 ... [详细]
    • 当unique验证运到图片上传时
      2019独角兽企业重金招聘Python工程师标准model:public$imageFile;publicfunctionrules(){return[[[na ... [详细]
    • 理解文档对象模型(DOM)
      本文介绍了文档对象模型(DOM)的基本概念,包括其作为HTML文档的节点树结构,以及如何通过JavaScript操作DOM来实现网页的动态交互。 ... [详细]
    • 深入解析ES6至ES8的新特性与应用
      本文详细介绍了自2015年发布的ECMAScript 6.0(简称ES6)以来,JavaScript语言的多项重要更新,旨在帮助开发者更好地理解和利用这些新特性进行复杂应用的开发。 ... [详细]
    author-avatar
    四只猪1984
    这个家伙很懒,什么也没留下!
    Tags | 热门标签
    RankList | 热门文章
    PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
    Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有