热门标签 | 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中的一致 
  •     }); 
  •  } 

  • 推荐阅读
    • 本文介绍了如何使用jQuery和AJAX来实现动态更新两个div的方法。通过调用PHP文件并返回JSON字符串,可以将不同的文本分别插入到两个div中,从而实现页面的动态更新。 ... [详细]
    • 本文介绍了DataTables插件的官方网站以及其基本特点和使用方法,包括分页处理、数据过滤、数据排序、数据类型检测、列宽度自动适应、CSS定制样式、隐藏列等功能。同时还介绍了其易用性、可扩展性和灵活性,以及国际化和动态创建表格的功能。此外,还提供了参数初始化和延迟加载的示例代码。 ... [详细]
    • 前言:关于跨域CORS1.没有跨域时,ajax默认是带cookie的2.跨域时,两种解决方案:1)服务器端在filter中配置详情:http:blog.csdn.netwzl002 ... [详细]
    • PHP图片截取方法及应用实例
      本文介绍了使用PHP动态切割JPEG图片的方法,并提供了应用实例,包括截取视频图、提取文章内容中的图片地址、裁切图片等问题。详细介绍了相关的PHP函数和参数的使用,以及图片切割的具体步骤。同时,还提供了一些注意事项和优化建议。通过本文的学习,读者可以掌握PHP图片截取的技巧,实现自己的需求。 ... [详细]
    • 从零基础到精通的前台学习路线
      随着互联网的发展,前台开发工程师成为市场上非常抢手的人才。本文介绍了从零基础到精通前台开发的学习路线,包括学习HTML、CSS、JavaScript等基础知识和常用工具的使用。通过循序渐进的学习,可以掌握前台开发的基本技能,并有能力找到一份月薪8000以上的工作。 ... [详细]
    • 本文介绍了Java后台Jsonp处理方法及其应用场景。首先解释了Jsonp是一个非官方的协议,它允许在服务器端通过Script tags返回至客户端,并通过javascript callback的形式实现跨域访问。然后介绍了JSON系统开发方法,它是一种面向数据结构的分析和设计方法,以活动为中心,将一连串的活动顺序组合成一个完整的工作进程。接着给出了一个客户端示例代码,使用了jQuery的ajax方法请求一个Jsonp数据。 ... [详细]
    • 本文介绍了使用FormData对象上传文件同时附带其他参数的方法。通过创建一个表单,将文件和参数添加到FormData对象中,然后使用ajax发送POST请求进行文件上传。在发送请求时,需要设置processData为false,告诉jquery不要处理发送的数据;同时设置contentType为false,告诉jquery不要设置content-Type请求头。 ... [详细]
    • Jquery 跨域问题
      为什么80%的码农都做不了架构师?JQuery1.2后getJSON方法支持跨域读取json数据,原理是利用一个叫做jsonp的概念。当然 ... [详细]
    • mui框架offcanvas侧滑超出部分隐藏无法滚动如何解决
      web前端|js教程off-canvas,部分,超出web前端-js教程mui框架中off-canvas侧滑的一个缺点就是无法出现滚动条,因为它主要用途是设置类似于qq界面的那种格 ... [详细]
    • Allegro总结:1.防焊层(SolderMask):又称绿油层,PCB非布线层,用于制成丝网印板,将不需要焊接的地方涂上防焊剂.在防焊层上预留的焊盘大小要比实际的焊盘大一些,其差值一般 ... [详细]
    • 我将SpringMVC升级到Spring3.2.5.我的一些剩余调用即使存在,也会返回无法识别的字段异常.这是错误.Resolvingexceptionfrom ... [详细]
    • 关于extjs开发实战pdf的信息
      本文目录一览:1、extjs实用开发指南2、本 ... [详细]
    • asp.net(vb脚本)如何获取xml的节点值?xmlversion1.0encodingutf-8?rootimageimagemenusmenuurl#frame_paren ... [详细]
    • 1、概述首先和大家一起回顾一下Java消息服务,在我之前的博客《Java消息队列-JMS概述》中,我为大家分析了:然后在另一篇博客《Java消息队列-ActiveMq实战》中 ... [详细]
    • 例如控件ID为user.id使用$(#user.id)不能得到正确的结果必须使用\\转义即$(#user\\.id)转载于:https:www.cnblogs.comrch ... [详细]
    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社区 版权所有