谁可相欹 发表于 2015-2-3 23:54:18

PHP网站制作之Show_page 一个通用的数据库分页类

从刚开始练习的PHP基础语法练习,到PHP语言在WEB中的应用,再到实际的项目开发,如留言版,相册系统,中小型公司网站系统,以及期间做过的有关团队合作的小游戏,让我受益匪浅,学到了很多。分页|数据|数据库   具体引见:
   记得之前总感觉数据库分页费事,而网上的一些分页类又总感到太繁琐,因而这个类就出生了。:D
现在写这个类的时分就是想把分页复杂化。您在利用这个类的时分只需把纪录数,页数巨细和要传递的变量传过去,剩下的一切城市主动弄定。有甚么成绩请到服装论坛提出。

<?php
/**
* 一个用于Mysql数据库的分页类
*
* @author      Avenger <avenger@php.net>
* @version   1.0
* @lastupdate2003-04-08 11:11:33
*
*
* 利用实例:
* $p = new show_page;//创立新对像
* $p->file="ttt.php";//设置文件名,默许为以后页
* $p->pvar="pagecount"; //设置页面传递的参数,默许为p
* $p->setvar(array("a" => '1', "b" => '2')); //设置要传递的参数,要注重的是此函数必需要在 set 前利用,不然变量传不外去
* $p->set(20,2000,1);//设置相干参数,共三个,分离为'页面巨细'、'总纪录数'、'以后页(假如为空则主动读取GET变量)'
* $p->output(0);   //输入,为0时直接输入,不然前往一个字符串
* echo $p->limit();//输入Limit子句。在sql语句顶用法为 "SELECT * FROM TABLE LIMIT {$p->limit()}";
*
*/

class show_page {
    /**
   * 页面输入了局
   *
   * @var string
   */
var $output;
    /**
   * 利用该类的文件,默许为 PHP_SELF
   *
   * @var string
   */
var $file;
    /**
   * 页数传递变量,默许为 'p'
   *
   * @var string
   */
var $pvar = "p";
    /**
   * 页面巨细
   *
   * @var integer
   */
var $psize;
    /**
   * 以后页面
   *
   * @var ingeger
   */
var $curr;
    /**
   * 要传递的变量数组
   *
   * @var array
   */
var $varstr;
    /**
   * 总页数
   *
   * @var integer
   */
    var $tpage;
    /**
   * 分页设置
   *
   * @access public
   * @param int $pagesize 页面巨细
   * @param int $total    总纪录数
   * @param int $current以后页数,默许会主动读取
   * @return void
   */
    function set($pagesize=20,$total,$current=false) {
global $HTTP_SERVER_VARS,$HTTP_GET_VARS;
$this->tpage = ceil($total/$pagesize);
if (!$current) {$current = $HTTP_GET_VARS[$this->pvar];}
if ($current>$this->tpage) {$current = $this->tpage;}
if ($current<1) {$current = 1;}
$this->curr= $current;
$this->psize = $pagesize;
if (!$this->file) {$this->file = $HTTP_SERVER_VARS['PHP_SELF'];}
if ($this->tpage > 1) {
            
   if ($current>10) {
    $this->output.='<a href='.$this->file.'?'.$this->pvar.'='.($current-10).($this->varstr).' title="前十页"><<<</a> ';
   }
            if ($current>1) {
    $this->output.='<a href='.$this->file.'?'.$this->pvar.'='.($current-1).($this->varstr).' title="前一页"><<</a> ';
   }
            $start = floor($current/10)*10;
            $end = $start+9;
            if ($start<1)   {$start=1;}
            if ($end>$this->tpage) {$end=$this->tpage;}
            for ($i=$start; $i<=$end; $i++) {
                if ($current==$i) {
                  $this->output.='<font color="red">'.$i.'</font> ';    //输入以后页数
                } else {
                  $this->output.='<a href="'.$this->file.'?'.$this->pvar.'='.$i.$this->varstr.'">['.$i.']</a> ';    //输入页数
                }
            }
            if ($current<$this->tpage) {
    $this->output.='<a href='.$this->file.'?'.$this->pvar.'='.($current+1).($this->varstr).' title="下一页">>></a> ';
   }
            if ($this->tpage>10 && ($this->tpage-$current)>=10 ) {
    $this->output.='<a href='.$this->file.'?'.$this->pvar.'='.($current+10).($this->varstr).' title="下十页">>>></a>';
   }
}
}
    /**
   * 要传递的变量设置
   *
   * @access public
   * @param array $data   要传递的变量,用数组来暗示,拜见下面的例子
   * @return void
   */
function setvar($data) {
foreach ($data as $k=>$v) {
   $this->varstr.='&'.$k.'='.urlencode($v);
}
}
    /**
   * 分页了局输入
   *
   * @access public
   * @param bool $return 为真时前往一个字符串,不然直接输入,默许直接输入
   * @return string
   */
function output($return = false) {
if ($return) {
   return $this->output;
} else {
   echo $this->output;
}
}
    /**
   * 生成Limit语句
   *
   * @access public
   * @return string
   */
    function limit() {
return (($this->curr-1)*$this->psize).','.$this->psize;
}
} //End Class
?>

PHP于1994年由Rasmus Lerdorf创建,刚刚开始是Rasmus Lerdorf为了要维护个人网页而制作的一个简单的用Perl语言编写的程序。

小妖女 发表于 2015-2-4 06:57:32

刚开始安装php的时候,我图了个省事,把php的扩展全都打开啦(就是把php.ini 那一片 extension 前面的冒号全去掉啦),这样自然有好处,以后不用再需要什么功能再来打开。

兰色精灵 发表于 2015-2-6 00:14:22

本文当是我的笔记啦,遇到的问题随时填充

乐观 发表于 2015-2-7 02:54:22

首推的搜索引擎当然是Google大神,其次我比较喜欢 百度知道。不过搜出来的结果往往都是 大家copy来copy去的,运气的的概率很大。

不帅 发表于 2015-2-19 22:20:34

最后祝愿,php会给你带来快乐的同时 你也会给他带来快乐。

变相怪杰 发表于 2015-2-21 06:29:18

我还是推荐用firefox ,配上firebug 插件调试js能省下不受时间。谷歌的浏览器最好也不少用,因为谷歌的大侠们实在是太天才啦,把一些原来的js代码加了一些特效。

柔情似水 发表于 2015-2-21 14:39:49

先学习php和mysql,还有css(html语言很简单)我认为现在的效果比以前的方法好。

谁可相欹 发表于 2015-2-23 21:44:20

其实没啥难的,多练习,练习写程序,真正的实践比看100遍都有用。不过要熟悉引擎

再见西城 发表于 2015-3-2 09:15:25

建议加几个专业的phper的群,当然啦需要说话的人多,一处一点问题能有人回答你的,当然啦要让人回答你的问题,平时就得躲在里面聊天,大家混熟啦,愿意回答你问题的人自然就多啦。

深爱那片海 发表于 2015-3-3 15:40:33

有时候汉字的空格也能导致页面出错,所以在写代码的时候,要输入空格最好用引文模式。

再现理想 发表于 2015-3-12 19:26:24

我还是推荐用firefox ,配上firebug 插件调试js能省下不受时间。谷歌的浏览器最好也不少用,因为谷歌的大侠们实在是太天才啦,把一些原来的js代码加了一些特效。

若天明 发表于 2015-3-20 01:49:20

其实也不算什么什么心得,在各位大侠算是小巫见大巫了吧,望大家不要见笑,若其中有错误的地方请各位大虾斧正。

金色的骷髅 发表于 2015-3-26 14:02:06

对于初学者来说不推荐去拿钱买的。当然如果一个网站你经常去用,而且里面的资料也比较有用,最好还是买个会员比较好,毕竟那些也是别人的工作成果。

愤怒的大鸟 发表于 2015-3-26 21:26:57

说php的话,首先得提一下数组,开始的时候我是最烦数组的,总是被弄的晕头转向,不过后来呢,我觉得数组里php里最强大的存储方法,所以建议新手们要学好数组。

小魔女 发表于 2015-3-27 05:09:15

其实也不算什么什么心得,在各位大侠算是小巫见大巫了吧,望大家不要见笑,若其中有错误的地方请各位大虾斧正。

admin 发表于 2015-4-1 00:51:56

php是动态网站开发的优秀语言,在学习的时候万万不能冒进。在系统的学习前,我认为不应该只是追求实现某种效果,因为即使你复制他人的代码调试成功,实现了你所期望的效果,你也不了解其中的原理。

飘飘悠悠 发表于 2015-4-10 11:43:49

我学习了一段时间后,我发现效果并不好(估计是我自身的问题)。因为一个人的精力总是有限的,同时学习这么多,会导致每个的学习时间都得不到保证。

冷月葬花魂 发表于 2015-4-11 19:58:49

当留言板完成的时候,下步可以把做1个单人的blog程序,做为目标,

活着的死人 发表于 2015-5-1 07:08:58

做为1门年轻的语言,php一直很努力。

若相依 发表于 2015-5-4 03:30:15

学好程序语言,多些才是王道,写两个小时代码的作用绝对超过看一天书,这个我是深有体会(顺便还能练打字速度)。
页: [1]
查看完整版本: PHP网站制作之Show_page 一个通用的数据库分页类