-
- /**
- * ファイル名: ext_page.class.php
- * @package:phpbean
- * 説明: 超強力なページング クラス、4 つのページング モード、デフォルトのページング スタイルは Baidu や Google に似ています。
- * 2.0 追加機能: カスタム スタイル、カスタム スタイルをサポート、PHP4 と PHP5 の両方をサポート、
- * 例:
- * 4 つのページング モード:
- require_once('../libs/classes/page.class.php' ); page=new page(array('total'=>1000,'perpage'=>20));
- echo 'mode:1
'.$page->show(); hr>mode:2 '.$page->show(2);
- echo '
mode:3 '
- echo '< hr>mode:4
'.$page->show(4);
- AJAX をオンにする:
- $ajaxpage=new page(array('total'=>1000,'perpage'=> ;20, 'ajax'=>'ajax_page','page_name'=>'test'));
- echo 'mode:1
'.$ajaxpage->show();
- 継承カスタマイズのページネーション表示モードを使用します。
- 編集: スクリプト スクール http://bbs.it-home.org
- */
- class _page
- {
- /**
- * 設定、公開
- */
- var $page_name="PB_page";// URL の制御に使用されるページタグページ。たとえば、xxx.php?PB_page=2 の PB_page
- var $next_page='>';//次のページ
- var $pre_page='<';//前のページ
- var $first_page='First' ;/ /Homepage
- var $last_page='Last';//最後のページ
- var $pre_bar='<<';//前のページングバー
- var $next_bar='>>';//次のページングバー
- var $format_left='[';
- var $format_right=']';
- var $is_ajax=false;//AJAX ページング モードがサポートされているかどうか
-
- /**
- *プライベート
- *
- */
- var $pagebarnum= 10; //レコードストリップの数を制御します。
- var $totalpage=0;//総ページ数
- var $ajax_action_name='';//AJAXアクション名
- var $nowindex=1;//現在のページ
- var $url="";//URLアドレスヘッダー
- var $offset=0;
-
- /**
- * コンストラクター构造関数数
- *
- * @param array $array['total'],$array['perpage'],$array['nowindex'],$array['url'],$array['ajax' ]...
- */
- 関数ページ($array)
- {
- if(is_array($array)){
- if(!array_key_exists('total',$array)) $ this->error(__FUNCTION__,'total のパラメータが必要です');
- $total=intval($array['total']);
- $perpage=(array_key_exists('perpage',$array))?intval ( $array['perpage']):10;
- $nowindex=(array_key_exists('nowindex',$array))?intval($array['nowindex']):''; URL ',$array))?$array['url']:'';
- }else{
- $perpage='';
- }
- if((!is_int($total))||($total if(!empty($array['page_name']) ) )$this->set('page_name',$array['page_name']);// ページ名を設定
- $this->_set_nowindex($nowindex);// 現在のページを設定
- $this-> _set_url( $url);// リンクアドレスを設定します
- $this->totalpage=ceil($total/$perpage);
- $this->offset=($this->nowindex-1)*$perpage ;
- if (!empty($array['ajax']))$this->open_ajax($array['ajax']);//AJAX モードを開く
- }
- /**
- * 指定された変数名の値をクラスに設定します。変更がこのクラスに属さない場合、例外がスローされます
- *
- * @param string $var
- * @param string $value
- */
- 関数set($ var,$value)
- {
- if(in_array($var,get_object_vars($this)))
- $this->$var=$value;
- else {
- $this->error(__FUNCTION__, $var. " は PB_Page に属しません!");
- }
- }
- /**
- * 逆 AJAX モードをオンにする
- *
- * @param string $action デフォルトの ajax トリガー アクション。
- */
- function open_ajax($action)
- {
- $this->is_ajax=true;
- $this->ajax_action_name=$action;
- }
- /**
- * 「次のページ」を表示するコードを取得します
- *
- * @param string $style
- * @return string
- */
- function next_page($style='')
- {
- if($this->nowindextotalpage){
- return $this->_get_link( $this->_get_url($this->>nowindex+1),$this->next_page,$style);
- }
- return ''.$this->next_page.'';
- }
-
- /**
- * 「前のページ」を表示するコードを取得します
- *
- * @param string $style
- * @return string
- */
- function pre_page($style='')
- {
- if($this->nowindex>1){
- return $this->gt;_get_link($this-> ;_get_url($this->nowindex-1),$this->pre_page,$style);
- }
- return ''.$this->pre_page.'';
- }
-
- /**
- * 「ホームページ」を表示するコードを取得します
- *
- * @return string
- */
- function first_page($style='')
- {
- if($this->nowindex==1){
- return ''.$this->first_page.'';
- }
- return $this->_get_link($this->_get_url(1),$this->first_page,$style);
- }
-
- /**
- * 「最後のページ」を表示するコードを取得します
- *
- * @return string
- */
- function last_page($style='')
- {
- if($this->nowindex==$this->totalpage){
- return ''.$this->last_page.'';
- }
- return $this->_get_link($this->_get_url($this->totalpage),$this->last_page,$style);
- }
-
- 関数 nowbar($style='',$nowindex_style='')
- {
- $plus=ceil($this->pagebarnum/2);
- if($this->pagebarnum-$plus+$this->nowindex>$this->totalpage)$plus=($this->pagebarnum-$this->totalpage+$this->nowindex) ;
- $begin=$this->nowindex-$plus+1;
- $begin=($begin>=1)?$begin:1;
- $return='';
- for($i=$begin;$i<$begin+$this->pagebarnum;$i++)
- {
- if($i<=$this->totalpage){
- if($i!=$this ->nowindex)
- $return.=$this->_get_text($this->_get_link($this->_get_url($i),$i,$style));
- else
- $return.=$this->_get_text(''.$i.'');
- }else{
- 休憩;
- }
- $return.="n";
- }
- unset($begin);
- $return を返します;
- }
- /**
- * ジャンプボタンを表示するコードを取得します
- *
- * @return string
- */
- function select()
- {
- $return='
- for($i=1;$i<=$this->totalpage;$i++)
- {
- if($i==$this->nowindex){
- $return.='<オプション値= "'.$i.'" selected>'.$i.'';
- }else{
- $return.='';
- }
- }
- unset($i);
- $return.='';
- $return を返します;
- }
-
- /**
- * mysql ステートメントの制限に必要な値を取得します
- *
- * @return string
- */
- function offset()
- {
- return $this->offset;
- }
-
- /**
- * ページング表示スタイルの制御 (対応するスタイルを追加できます)
- *
- * @param int $mode
- * @return string
- */
- function show($mode=1)
- {
- switch ($mode)
- {
- case '1':
- $this->next_page='下一页';
- $this->pre_page='上一页';
- return $this->pre_page().$this->nowbar().$this->next_page().'第'.$this->select().'页';
- 休憩;
- ケース '2':
- $this->next_page='下一页';
- $this->pre_page='上一页';
- $this->first_page='首页';
- $this->last_page='尾页';
- return $this->first_page().$this->pre_page().'[第'.$this->nowindex.'页]'.$this->next_page().$this-> ;last_page().'第'.$this->select().'页';
- 休憩;
- ケース '3':
- $this->next_page='下一页';
- $this->pre_page='上一页';
- $this->first_page='首页';
- $this->last_page='尾页';
- return $this->first_page().$this->pre_page().$this->next_page().$this->last_page();
- 休憩;
- ケース '4':
- $this->next_page='下一页';
- $this->pre_page='上一页';
- return $this->pre_page().$this->nowbar().$this->next_page();
- 休憩;
- case '5':
- return $this->pre_bar().$this->pre_page().$this->nowbar().$this->next_page().$this->next_bar ();
- 休憩;
- ケース '6':
- return $this->select();
- 休憩;
- ケース '7':
- return $this->nowbar();
- 休憩;
- }
-
- }
- /*----------------private function (私有メソッド)---------------------- ---------------------------------------*/
- /**
- * URLヘッダーアドレスを設定します
- * @param: String $url
- * @return boolean
- */
- function _set_url($url="")
- {
- if(!empty($url)){
- //手動设置
- $this->url=$url.((stristr($url,'?') )?'&':'?').$this->page_name."=";
- }else{
- //自動获取
- if(empty($_SERVER['QUERY_STRING'])){
- //QUERY_STRING が存在しないとき
- $this->url=$_SERVER['REQUEST_URI']."?" .$this->page_name."=";
- }else{
- //
- if(stristr($_SERVER['QUERY_STRING'],$this->page_name.'=')){
- //地址存在页面パラメータ
- $this->url=str_replace( $this->page_name.'='.$this->nowindex,'',$_SERVER['REQUEST_URI']);
- $last=$this->url[strlen($this->url)-1];
- if($last=='?'||$last=='&'){
- $this->url.=$this->page_name."=";
- }else{
- $this->url.='&'.$this->page_name."=";
- }
- }else{
- //
- $this->url=$_SERVER['REQUEST_URI'].'&'.$this->page_name.'=';
- }//end if
- }//end if
- }//end if
- }
-
- /**
- * 現在のページを設定します
- *
- */
- function _set_nowindex($nowindex)
- {
- if(empty($nowindex)){
- //系统获取
-
- if(isset($_GET[$this->page_name])){
- $this->nowindex=intval($_GET[$this->page_name]);
- }
- if(isset($_POST['PB_Page_Select'])){
- $this->nowindex=$_POST['PB_Page_Select'];
- }
- }else{
- //手動設定
- $this->nowindex=intval($nowindex);
- }
- }
-
- /**
- * 指定されたページのアドレス値を返します
- *
- * @param int $pageno
- * @return string $url
- */
- function _get_url($pageno=1)
- {
- return $this->url.$pageno;
- }
-
- /**
- * ページネーションの表示テキストを取得します。たとえば、デフォルトでは _get_text('1') は [1] を返します
- *
- * @param 文字列 $str
- * @return 文字列 $url
- */
- function _get_text($str)
- {
- return $this->format_left.$str.$this->format_right;
- }
-
- /**
- * リンクアドレスを取得します
- */
- function _get_link($url,$text,$style=''){
- $style=(empty($style))?'':'class="'。 $style.'"';
- if($this->is_ajax){
- //結果として AJAX モードを使用します
- return ''.$text.'';
- }else{
- return ''.$text.'';
- }
- }
- /**
- ※エラー時の対処方法
- */
- function error($function,$errormsg)
- {
- die('ファイル '.__FILE__.' ,関数 '. $function.'() :'.$errormsg);
- }
- }
-
- // ページング クラスを継承し、データベース アクセス機能を追加します。
- var $db;接続されたオブジェクト
- var $_Sql_Query = ''; // データベースの SQL をクエリします
- var $_Total = 0; // クエリされるレコードの合計が
- である必要があります var $_Rst = array();
- / **
- * ページング クエリ ライブラリ
- *
- * @param String $Sql レコード クエリ SQL ステートメント
- * @param int $pagen 現在のページ。ページング リンクに取り込まれるパラメータ。
- * @param String $pname 特別な要件がある場合のデフォルトは、index.php?xx=b&bb=33&page=2 です。 $pname のパラメータを変更できます。例: $pname='db_page' は、index.php?xx=b&bb=33&db_page=2
- * @return Mysql_Page
- となります。*/
-
- function Page($db, $sql_query = '', $max_rows_per_page = 20, $current_page_number = 0, $url = '', $parameters = '', $pname = 'PB_page ', $otc = '*') {
- $this ->
- $pos_to = strlen($sql_query);
- $pos_group_by = strpos ($sql_query, ' group by', $pos_from);
- if (($pos_group_by < $pos_to) && ($pos_group_by != false)) $pos_to = $pos_group_by
- $pos_having = strpos($sql_query, ' を持っています ', $pos_from);
- if (($pos_having < $pos_to) && ($pos_having != false)) $pos_to = $pos_having
- $pos_order_by = strpos($sql_query, ' order by', $pos_from; );
- if (($pos_order_by < $pos_to) && ($pos_order_by != false)) $pos_to = $pos_order_by ($this -> db -> otc) as total " .substr($sql_query, $pos_from, ($pos_to - $pos_from)));
- $query_num_rows = $reviews_count[0]['total'];
- $this -> _Total = $query_num_rows;
- $num_pages = ceil($query_num_rows / $max_rows_per_pages);
- if ($current_page_number > $num_pages) {
- $current_page_number = $num_pages; }
- $offset = ($max_rows_per_page * ($current_page_number - 1));
- if ($offset if ($offset > 0) {
- $offset = $offset + 1; }
- $this -> $sql_query 。 offset . ", " . $max_rows_per_page;
- $this -> setData() // データベースをクエリします。 $query_num_rows, 'perpage' => , 'page_name' = > $pname, 'url' => $url, 'parameters' => $parameters));
-
- /**
- * 現在のページのレコードを取得し、配列を返します。*/
- 関数 findByAll() $this ->Rst;
- /**
- * ページング情報を表示します
- *
- * @param int $model
- */
- 関数 dispaly_links($model) {
- $this -> show($model) }
- /**
- * レコードの数を返します
- *
- * @return Int
- */
- 関数 getCount() {
- return $this -> _Total }
- /**
- * クエリ結果レコードの数を取得します。
- *
- * @return Int
- */
- function getRows() {
- return $this -> _Rst; }
-
- * クエリ関数を実行します。
- * プライベートメソッド。*/
- 関数 setData() { _Rst = $this -> getResults($this -> _Sql_Query);
-
-
- ;コード
-
-
-
-
-
-
-
-
-
-
-
-
|