使用方法:
第一步:include 'lib/page.php';
//
引入文件
第二步:$page=new Page($musiclist->findCount(),5);
//
实例化类,并传入数据总数和分页数
第三步:$this->results = $musiclist->findAll(null, "music_time DESC ",null,$page->limit);
//
查找数据时将$page->limit传入
第四步:$this->pages = $page->fpage(4,5,6,0,2);
//
显示分页
$this->display("music01/admin/music.html");
总结: 上例是SMARTY里面使用的方法:页面直接写{<$page>} 就可以显示了。
$page->fpage(4,5,6,0,2);输入数字的不同可以显示不同的效果。
<?php
class Page {
private $total; //数据表中总记录数
private $listRows; //每页显示行数
private $limit; //SQL语句使用limit从名
private $uri; //url地址
private $pageNum; //页数
private $page;
//在分页信息中显示内容,可以自己设置
private $config=array('head'=>"条记录", "prev"=>"上一页", "next"=>"下一页", "first"=>"首页", "last"=>"末页");
private $listNum=10; //默认分页列表显示的个数
/**
* 构造方法,可以设置分页类的属性
* @param int $total 计算分页的总记录数
* @param int $listRows 可选的,默认每页需要显示的记录数
* @param string $pa 可选的,为向目标页面传递参数
* @param bool $ord 可选的,默认值为true, 如果为true默认页为第一页,false则为最后一页
*/
public function __construct($total, $listRows=25, $pa="", $ord=true){
$this->total=$total;
$this->listRows=$listRows;
$this->uri=$this->getUri($pa);
$this->pageNum=ceil($this->total/$this->listRows);
if(!empty($_GET["page"])) {
$page=$_GET["page"];
}else{
if($ord)
$page=1;
else
$page=$this->pageNum;
}
if($total > 0) {
if(preg_match('/\D/', $page) ){
$this->page=1;
}else{
$this->page=$page;
}
}else{
$this->page=0;
}
$this->limit=$this->setLimit();
}
/**
* 用于设置显示分页的信息,可以连贯操作
* @param string $param 是数组config的下标
* @param string $value 用于设置config下标对应的元素值
* @return object 返回本对象自己$this
*/
function set($param, $value){
if(array_key_exists($param, $this->config)){
$this->config[$param]=$value;
}
return $this;
}
private function setLimit(){
if($this->page > 0)
return ($this->page-1)*$this->listRows.", {$this->listRows}";
else
return 0;
}
private function getUri($pa){
if($pa==""){
return $_SERVER['PHP_SELF'].'?c='.$_GET["c"].'&a='.$_GET["a"].'&';
}else{
return $_SERVER['PHP_SELF'].'?c='.$_GET["c"].'&a='.$_GET["a"].'&'.$pa.'='.$_GET[$pa].'&';
}
}
private function __get($args){
if($args=="limit" || $args=="page")
return $this->$args;
else
return null;
}
private function start(){
if($this->total==0)
return 0;
else
return ($this->page-1)*$this->listRows+1;
}
private function end(){
return min($this->page*$this->listRows,$this->total);
}
private function firstprev(){
if($this->page > 1) {
$str=" <a href='{$this->uri}page=1'>{$this->config["first"]}</a>";
$str.=" <a href='{$this->uri}page=".($this->page-1)."'>{$this->config["prev"]}</a> ";
return $str;
}
}
private function pageList(){
$linkPage=" <b>";
$inum=floor($this->listNum/2);
for($i=$inum; $i>=1; $i--){
$page=$this->page-$i;
if($page>=1)
$linkPage.="<a href='{$this->uri}page={$page}'>{$page}</a> ";
}
if($this->pageNum > 1)
$linkPage.="<span style='padding:1px 2px;background:#BBB;color:white'>{$this->page}</span> ";
for($i=1; $i<=$inum; $i++){
$page=$this->page+$i;
if($page<=$this->pageNum)
$linkPage.="<a href='{$this->uri}page={$page}'>{$page}</a> ";
else
break;
}
$linkPage.='</b>';
return $linkPage;
}
private function nextlast(){
if($this->page != $this->pageNum) {
$str=" <a href='{$this->uri}page=".($this->page+1)."'>{$this->config["next"]}</a> ";
$str.=" <a href='{$this->uri}page=".($this->pageNum)."'>{$this->config["last"]}</a> ";
return $str;
}
}
private function goPage(){
if($this->pageNum > 1) {
return ' <input style="width:20px;height:17px !important;height:18px;border:1px solid #CCCCCC;" type="text" onkeydown="javascript:if(event.keyCode==13){var page=(this.value>'.$this->pageNum.')?'.$this->pageNum.':this.value;location=\''.$this->uri.'page=\'+page+\'\'}" value="'.$this->page.'"><input style="cursor:pointer;width:25px;height:18px;border:1px solid #CCCCCC;" type="button" value="GO" onclick="javascript:var page=(this.previousSibling.value>'.$this->pageNum.')?'.$this->pageNum.':this.previousSibling.value;location=\''.$this->uri.'page=\'+page+\'\'"> ';
}
}
private function disnum(){
if($this->total > 0){
return $this->end()-$this->start()+1;
}else{
return 0;
}
}
/**
* 按指定的格式输出分页
* @param int 为0-7的数字,每个数字作为一个参数,可以自定义输出分页结构和调整结构的顺序
* @return string 分页信息内容
*/
function fpage(){
$arr=func_get_args();
$html[0]=" 共<b> {$this->total} </b>{$this->config["head"]} ";
$html[1]=" 本页 <b>".$this->disnum()."</b> 条 ";
$html[2]=" 本页从 <b>{$this->start()}-{$this->end()}</b> 条 ";
$html[3]=" <b>{$this->page}/{$this->pageNum}</b>页 ";
$html[4]=$this->firstprev();
$html[5]=$this->pageList();
$html[6]=$this->nextlast();
$html[7]=$this->goPage();
$fpage='<div style="font:12px \'\5B8B\4F53\',san-serif;">';
if(count($arr) < 1)
$arr=array(0, 1,2,3,4,5,6,7);
for($i=0; $i<count($arr); $i++)
$fpage.=$html[$arr[$i]];
$fpage.='</div>';
return $fpage;
}
}
分享到:
相关推荐
该组件提供了一个基本的分页控件,能够满足大多数情况下的分页需求。 分页组件的结构 分页组件的结构主要由以下几个部分组成: * 分页控件容器 `<div id="pageDiv" class="text-right">` * 分页控件 `...
"基于存储过程+分页控件+分页类的无敌分页模式"是一个高效的数据查询和展示策略,它结合了数据库优化、前端界面控制以及后端数据处理的最佳实践。下面将详细解析这一模式的关键知识点。 首先,**存储过程(Stored ...
分页界面通常包含“首页”、“上一页”、“下一页”、“尾页”按钮,以及一个显示当前页码和可输入目标页码的文本框,以及一个“GO”按钮来触发跳转操作。这样的设计允许用户方便地在不同页面间切换。 3. **事件...
6. **自定义标签库**:小范分页控件是一个定制的JSP标签库,它提供了丰富的属性和方法,如当前页、总页数、跳转页数等,方便开发者在JSP页面中灵活地展示和控制分页。 7. **样式与交互**:虽然标签库提供了基本的...
Hibernate是一个对象关系映射(ORM)框架,它简化了Java应用与数据库之间的交互。在分页显示中,Hibernate的Criteria、HQL或SQL查询可以用来从数据库中选取特定范围的数据。它提供了SessionFactory和Session接口,...
例如,可以创建一个`pagination.ftl`宏库,包含`firstPage`、`prevPage`、`nextPage`、`lastPage`等宏,以便于在模板中方便地调用。 5. **传递数据到视图**:在Action的execute方法或者专门的分页处理方法中,将...
2. **创建分页类**: 设计一个基础的分页类,包含当前页数、每页条数、总页数、总记录数等属性。这个类可以作为所有分页操作的基类,提供计算总页数和是否为最后一页等通用方法。 3. **编写分页服务**: 在Service层...
1. **方言支持**:由于不同的数据库(如MySQL、Oracle、SQL Server)在分页语法上存在差异,我们需要一个方言类来处理这些差异。MyBatis提供了方言接口,开发者可以自定义方言实现,覆盖不同的分页SQL语句。 2. **...
- **HTML结构**:创建一个包含分页按钮的容器,如`<ul class="pagination"></ul>`。 - **初始化插件**:引入jQuery分页插件(例如jQuery Pagination Plugin),并调用插件方法,设置每页显示的条数、总页数等参数...
在Struts2框架中,实现分页功能通常需要自定义一个分页类。上述代码展示了一个名为`NewPager`的分页类,该类封装了分页的核心逻辑。类中包含了以下关键属性: - `totalRows`: 总记录数,用于计算总页数。 - `...
在实际开发中,为提高代码复用性和减少重复工作,通常会实现一个通用的分页功能。 **Struts框架**是MVC(Model-View-Controller)架构的一种实现,它主要处理HTTP请求并将其映射到特定的Action,然后调用业务逻辑并...
3. **视图层(View)**:视图接收到模型返回的分页数据后,进行格式化和展示,包括显示每页的记录数、总页数、上一页和下一页的链接等。 **分页策略** 1. **前端分页**:所有分页逻辑都在前端完成,服务器一次性...
Struts2是一个基于MVC设计模式的Web应用框架,它继承了Struts1的优点并加入了更多现代Web应用的需求。在本项目中,Struts2负责处理HTTP请求,转发到相应的Action,然后调用业务逻辑,最后返回视图。Struts2的核心...
总结来说,"分页委托"是.NET开发中的一个高级技巧,它通过委托实现了数据访问层和业务逻辑层的解耦,提供了更灵活和高效的分页解决方案。通过阅读博文链接中的内容,你可以深入了解如何在实际项目中应用这一技术,...
6. **ExtJS比较**:ExtJS是一个成熟的富客户端JavaScript框架,拥有强大的组件库,但其渲染和响应速度相对较慢。而EdoJs设计的目标是提供更快的性能,特别是在数据密集型应用中。 7. **优化策略**:在实际项目中,...
"封装通用的Spring3+Struts2+JPA的CRUD 通用分页实现"是一个典型的Java Web开发实践,它结合了Spring框架的依赖注入、Struts2的MVC模式以及JPA(Java Persistence API)的数据持久层处理,来实现数据的创建、读取、...
在后端,比如使用Java的Spring Boot框架,可以创建一个服务接口,接收分页参数,然后调用上述SQL查询,将结果封装成对象返回。以下是一个简单的示例: ```java @GetMapping("/pagination") public ...
通过这个简单的PageBean分页例子,我们可以了解到在Java Web开发中如何优雅地处理大数据量的展示问题,同时也可以借鉴这个思路,根据不同项目需求定制更复杂的分页解决方案。理解并熟练运用PageBean,对于提升应用...
Spring提供了一个容器,用于管理对象的生命周期和依赖关系;SpringMVC负责处理HTTP请求和响应,协调应用程序的各部分;MyBatis则将SQL语句与Java代码解耦,使得数据库操作更为灵活。 **2. Maven** Maven是Java项目...
这种方法的优点是实现简单,但缺点是对服务器压力小,如果数据量非常大,可能会消耗大量内存,影响性能。 2. 后端分页:服务器只返回当前页所需的数据,减少了网络传输的数据量和客户端的内存占用。这种策略更适合...