ホームページ php教程 php手册 如何用ThinkPHP实现分页的功能(附代码)

如何用ThinkPHP实现分页的功能(附代码)

Jun 06, 2016 pm 08:18 PM
thinkphp ページネーション

这篇文章主要为大家详细介绍了ThinkPHP实现分页功能的相关代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

前几篇(上传,缩略图,验证码,自动验证表单)文章介绍的功能实现都是基于ThinkPHP框架封装好的类进行实现的,所以这次自己写一个分页类在框架中使用。

首先在根目录建一个Tools文件夹,在Tools文件夹下建Page.class.php类文件,这样以后自定义的工具类都可放在Tools文件夹下。

此类封装有以下函数:获取请求地址,开始页,从哪一条显示,结束页 从哪一条结束,页码列表(首页超链接,上一页,页码数字列表超链接,下一页,尾页,跳转),对于分页足够使用!

下面是Page.class.php代码

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

135

136

137

138

139

140

141

142

143

144

145

146

147

148

149

150

151

152

153

154

155

156

157

158

159

160

161

162

163

164

165

166

167

168

169

170

171

<?php

//命名空间的名称与上级目录tools一致

//原因:当前Page.class.php类文件会被自动加载机制引入

//   在引入的同时会把"tools"变为文件的上级目录,进而获得该Page类文件

namespace Tools;

 

class Page {

  private $total; //数据表中总记录数

  private $listRows; //每页显示行数

  private $limit;

  private $uri//当前链接URL

  private $pageNum; //页数

  private $config=array(&#39;header&#39;=>"个记录", "prev"=>"上一页", "next"=>"下一页", "first"=>"首 页", "last"=>"尾 页");

  private $listNum=8; //限制页码列表数目

   

  /*

   * $total 总记录数

   * $listRows 每页显示行数

   */

  public function __construct($total, $listRows=10, $pa=""){

    $this->total=$total//数据表中总记录数

    $this->listRows=$listRows; //设置每页显示行数

    $this->uri=$this->getUri($pa); //请求地址

    $this->page=!empty($_GET["page"]) ? $_GET["page"] : 1; //当前页

    $this->pageNum=ceil($this->total/$this->listRows); //总页数

    $this->limit=$this->setLimit(); //限制每页长度

  }

 

  private function setLimit(){

    return "Limit ".($this->page-1)*$this->listRows.", {$this->listRows}";

  }

 

  //请求地址

  private function getUri($pa){

    $url=$_SERVER["REQUEST_URI"].(strpos($_SERVER["REQUEST_URI"], &#39;?&#39;)?&#39;&#39;:"?").$pa;

    $parse=parse_url($url);

 

   

 

    if(isset($parse["query"])){

      parse_str($parse[&#39;query&#39;],$params);

      unset($params["page"]);

      $url=$parse[&#39;path&#39;].&#39;?&#39;.http_build_query($params);

       

    }

 

    return $url;

  }

 

  function __get($args){

    if($args=="limit")

      return $this->limit;

    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 first(){

    $html = "";

    if($this->page==1)

      $html.=&#39;&#39;;

    else

      $html.="  <a href=&#39;{$this->uri}&page=1&#39;>{$this->config["first"]}</a>  ";

 

    return $html;

  }

 

  //上一页

  private function prev(){

    $html = "";

    if($this->page==1)

      $html.=&#39;&#39;;

    else

      $html.="  <a href=&#39;{$this->uri}&page=".($this->page-1)."&#39;>{$this->config["prev"]}</a>  ";

 

    return $html;

  }

 

  //页码数字列表超链接

  private function pageList(){

    $linkPage="";

     

    $inum=floor($this->listNum/2);

   

    for($i=$inum; $i>=1; $i--){

      $page=$this->page-$i;

 

      if($page<1)

        continue;

 

      $linkPage.=" <a href=&#39;{$this->uri}&page={$page}&#39;>{$page}</a> ";

 

    }

   

    $linkPage.=" {$this->page} ";

     

 

    for($i=1; $i<=$inum; $i++){

      $page=$this->page+$i;

      if($page<=$this->pageNum)

        $linkPage.=" <a href=&#39;{$this->uri}&page={$page}&#39;>{$page}</a> ";

      else

        break;

    }

 

    return $linkPage;

  }

 

  //下一页

  private function next(){

    $html = "";

    if($this->page==$this->pageNum)

      $html.=&#39;&#39;;

    else

      $html.="  <a href=&#39;{$this->uri}&page=".($this->page+1)."&#39;>{$this->config["next"]}</a>  ";

 

    return $html;

  }

 

  //尾页

  private function last(){

    $html = "";

    if($this->page==$this->pageNum)

      $html.=&#39;&#39;;

    else

      $html.="  <a href=&#39;{$this->uri}&page=".($this->pageNum)."&#39;>{$this->config["last"]}</a>  ";

 

    return $html;

  }

 

  //跳转

  private function goPage(){

    return &#39;  <input type="text" onkeydown="javascript:if(event.keyCode==13){var page=(this.value>&#39;.$this->pageNum.&#39;)?&#39;.$this->pageNum.&#39;:this.value;location=\&#39;&#39;.$this->uri.&#39;&page=\&#39;+page+\&#39;\&#39;}" value="&#39;.$this->page.&#39;" style="width:25px"><input type="button" value="GO" onclick="javascript:var page=(this.previousSibling.value>&#39;.$this->pageNum.&#39;)?&#39;.$this->pageNum.&#39;:this.previousSibling.value;location=\&#39;&#39;.$this->uri.&#39;&page=\&#39;+page+\&#39;\&#39;">  &#39;;

  }

 

  //页码列表

  function fpage($display=array(0,1,2,3,4,5,6,7,8)){

    $html[0]="  共有<b>{$this->total}</b>{$this->config["header"]}  ";

    $html[1]="  每页显示<b>".($this->end()-$this->start()+1)."</b>条,本页<b>{$this->start()}-{$this->end()}</b>条  ";

    $html[2]="  <b>{$this->page}/{$this->pageNum}</b>页  ";

     

    $html[3]=$this->first();

    $html[4]=$this->prev();

    $html[5]=$this->pageList();

    $html[6]=$this->next();

    $html[7]=$this->last();

    $html[8]=$this->goPage();

    $fpage=&#39;&#39;;

    foreach($display as $index){

      $fpage.=$html[$index];

    }

 

    return $fpage;

 

  }

 

 

}

ログイン後にコピー

控制器代码:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

//商品列表

  function showlist(){

 

   //实现分页效果

   $goods = D(&#39;goods&#39;);

 

   //① 获得数据的总记录条数

   $total = $goods -> count(); //select count(*) from sw_goods;

   $per = 7; //每页显示7条记录

 

   //②实例化分页类

   $page_obj = new \Tools\Page($total, $per);

 

   //③自定义sql语句,获取每页信息

   $sql = "select * from sw_goods order by goods_id desc ".$page_obj->limit;

   $info = $goods->query($sql);

 

   //④获取页码列表

   $pagelist = $page_obj->fpage(array(3,4,5,6,7,8));

 

   //分配

   $this->assign(&#39;pagelist&#39;,$pagelist);

   $this->assign(&#39;info&#39;,$info);

   $this->display();

  }

ログイン後にコピー

前台显示代码

<{$pagelist}>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持PHP中文网。

【相关教程推荐】

1. php编程从入门到精通全套视频教程
2. php从入门到精通 
3. bootstrap教程

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

thinkphpプロジェクトの実行方法 thinkphpプロジェクトの実行方法 Apr 09, 2024 pm 05:33 PM

ThinkPHP プロジェクトを実行するには、Composer をインストールし、Composer を使用してプロジェクトを作成し、プロジェクト ディレクトリに入り、php bin/consoleserve を実行し、http://localhost:8000 にアクセスしてようこそページを表示する必要があります。

thinkphp にはいくつかのバージョンがあります thinkphp にはいくつかのバージョンがあります Apr 09, 2024 pm 06:09 PM

ThinkPHP には、さまざまな PHP バージョン向けに設計された複数のバージョンがあります。メジャー バージョンには 3.2、5.0、5.1、および 6.0 が含まれますが、マイナー バージョンはバグを修正し、新機能を提供するために使用されます。最新の安定バージョンは ThinkPHP 6.0.16 です。バージョンを選択するときは、PHP バージョン、機能要件、コミュニティ サポートを考慮してください。最高のパフォーマンスとサポートを得るには、最新の安定バージョンを使用することをお勧めします。

thinkphpの実行方法 thinkphpの実行方法 Apr 09, 2024 pm 05:39 PM

ThinkPHP フレームワークをローカルで実行する手順: ThinkPHP フレームワークをローカル ディレクトリにダウンロードして解凍します。 ThinkPHP ルート ディレクトリを指す仮想ホスト (オプション) を作成します。データベース接続パラメータを構成します。 Webサーバーを起動します。 ThinkPHP アプリケーションを初期化します。 ThinkPHP アプリケーションの URL にアクセスして実行します。

laravelとthinkphpではどちらが優れていますか? laravelとthinkphpではどちらが優れていますか? Apr 09, 2024 pm 03:18 PM

Laravel フレームワークと ThinkPHP フレームワークのパフォーマンスの比較: ThinkPHP は、最適化とキャッシュに重点を置いて、一般に Laravel よりもパフォーマンスが優れています。 Laravel は優れたパフォーマンスを発揮しますが、複雑なアプリケーションの場合は、ThinkPHP の方が適している可能性があります。

thinkphpのインストール方法 thinkphpのインストール方法 Apr 09, 2024 pm 05:42 PM

ThinkPHP のインストール手順: PHP、Composer、および MySQL 環境を準備します。 Composer を使用してプロジェクトを作成します。 ThinkPHP フレームワークと依存関係をインストールします。データベース接続を構成します。アプリケーションコードを生成します。アプリケーションを起動し、http://localhost:8000 にアクセスします。

開発に関する提案: ThinkPHP フレームワークを使用して非同期タスクを実装する方法 開発に関する提案: ThinkPHP フレームワークを使用して非同期タスクを実装する方法 Nov 22, 2023 pm 12:01 PM

「開発に関する提案: ThinkPHP フレームワークを使用して非同期タスクを実装する方法」 インターネット技術の急速な発展に伴い、Web アプリケーションには、多数の同時リクエストと複雑なビジネス ロジックを処理するための要件が​​ますます高まっています。システムのパフォーマンスとユーザー エクスペリエンスを向上させるために、開発者は多くの場合、電子メールの送信、ファイルのアップロードの処理、レポートの生成など、時間のかかる操作を実行するために非同期タスクの使用を検討します。 PHP の分野では、人気のある開発フレームワークとして ThinkPHP フレームワークが、非同期タスクを実装するための便利な方法をいくつか提供しています。

JavaScript を使用してテーブル ページング機能を実装するにはどうすればよいですか? JavaScript を使用してテーブル ページング機能を実装するにはどうすればよいですか? Oct 20, 2023 pm 06:19 PM

JavaScript を使用してテーブル ページング機能を実装するにはどうすればよいですか?インターネットの発展に伴い、テーブルを使用してデータを表示する Web サイトがますます増えています。データ量が多い場合には、ユーザー エクスペリエンスを向上させるためにデータをページに表示する必要があります。この記事では、JavaScript を使用してテーブル ページング機能を実装する方法と具体的なコード例を紹介します。 1. HTML 構造 まず、テーブルとページング ボタンをホストするための HTML 構造を準備する必要があります。 &lt;tab を使用できます

thinkphpのパフォーマンスはどうですか? thinkphpのパフォーマンスはどうですか? Apr 09, 2024 pm 05:24 PM

ThinkPHP は、キャッシュ メカニズム、コードの最適化、並列処理、データベースの最適化などの利点を備えた高性能 PHP フレームワークです。公式パフォーマンステストでは、1秒あたり10,000以上のリクエストを処理できることが示されており、実際のアプリケーションではJD.comやCtripなどの大規模なWebサイトやエンタープライズシステムで広く使用されています。

See all articles