Maison développement back-end tutoriel php Explication détaillée d'exemples de classe de page du framework tp et de pagination bootstrap

Explication détaillée d'exemples de classe de page du framework tp et de pagination bootstrap

Jun 27, 2017 pm 03:08 PM
bootstrap page thinkphp

Cet article présente principalement la classe de page du framework thinkphp et la pagination bootstrap (embellissement). Les amis qui en ont besoin peuvent se référer à la méthode d'utilisation du style

bootstrap. Écrivez le contenu du lien ici <.>

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

<nav aria-label="Page navigation">

 <ul class="pagination">

  <li>

   <a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" aria-label="Previous">

    <span aria-hidden="true">«</span>

   </a>

  </li>

  <li><a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" >1</a></li>

  <li><a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" >2</a></li>

  <li><a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" >3</a></li>

  <li><a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" >4</a></li>

  <li><a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" >5</a></li>

  <li>

   <a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" aria-label="Next">

    <span aria-hidden="true">»</span>

   </a>

  </li>

 </ul>

</nav>

 

1.找到Thinkphp中的Page.class.php,然后使用下面的文件内容完全替换

 

<?php

// +----------------------------------------------------------------------

// | ThinkPHP [ WE CAN DO IT JUST THINK IT ]

// +----------------------------------------------------------------------

// | Copyright (c) 2006-2014 http://thinkphp.cn All rights reserved.

// +----------------------------------------------------------------------

// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )

// +----------------------------------------------------------------------

// | Author: 麦当苗儿 <zuojiazi@vip.qq.com> <http://www.zjzit.cn>

// +----------------------------------------------------------------------

namespace Think;

class Page{

  public $firstRow; // 起始行数

  public $listRows; // 列表每页显示行数

  public $parameter; // 分页跳转时要带的参数

  public $totalRows; // 总行数

  public $totalPages; // 分页总页面数

  public $rollPage  = 11;// 分页栏每页显示的页数

  public $lastSuffix = true; // 最后一页是否显示总页数

  private $p    = &#39;p&#39;; //分页参数名

  private $url   = &#39;&#39;; //当前链接URL

  private $nowPage = 1;

  // 分页显示定制

  private $config = array(

    &#39;header&#39; => &#39;<li><span>共 %TOTAL_ROW% 条记录<span class="sr-only"></span></span></li>&#39;,

    &#39;prev&#39;  => &#39;<<&#39;,

    &#39;next&#39;  => &#39;>>&#39;,

    &#39;first&#39; => &#39;1...&#39;,

    &#39;last&#39;  => &#39;...%TOTAL_PAGE%&#39;,

    &#39;theme&#39; => &#39;%FIRST% %UP_PAGE% %LINK_PAGE% %DOWN_PAGE% %END%&#39;,

  );

  /**

   * 架构函数

   * @param array $totalRows 总的记录数

   * @param array $listRows 每页显示记录数

   * @param array $parameter 分页跳转的参数

   */

  public function construct($totalRows, $listRows=20, $parameter = array()) {

    C(&#39;VAR_PAGE&#39;) && $this->p = C(&#39;VAR_PAGE&#39;); //设置分页参数名称

    /* 基础设置 */

    $this->totalRows = $totalRows; //设置总记录数

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

    $this->parameter = empty($parameter) ? $_GET : $parameter;

    $this->nowPage  = empty($_GET[$this->p]) ? 1 : intval($_GET[$this->p]);

    $this->nowPage  = $this->nowPage>0 ? $this->nowPage : 1;

    $this->firstRow  = $this->listRows * ($this->nowPage - 1);

  }

  /**

   * 定制分页链接设置

   * @param string $name 设置名称

   * @param string $value 设置值

   */

  public function setConfig($name,$value) {

    if(isset($this->config[$name])) {

      $this->config[$name] = $value;

    }

  }

  /**

   * 生成链接URL

   * @param integer $page 页码

   * @return string

   */

  private function url($page){

    return str_replace(urlencode(&#39;[PAGE]&#39;), $page, $this->url);

  }

  /**

   * 组装分页链接

   * @return string

   */

  public function show() {

    if(0 == $this->totalRows) return &#39;&#39;;

    /* 生成URL */

    $this->parameter[$this->p] = &#39;[PAGE]&#39;;

    $this->url = U(ACTION_NAME, $this->parameter);

    /* 计算分页信息 */

    $this->totalPages = ceil($this->totalRows / $this->listRows); //总页数

    if(!empty($this->totalPages) && $this->nowPage > $this->totalPages) {

      $this->nowPage = $this->totalPages;

    }

    /* 计算分页零时变量 */

    $now_cool_page   = $this->rollPage/2;

    $now_cool_page_ceil = ceil($now_cool_page);

    $this->lastSuffix && $this->config[&#39;last&#39;] = $this->totalPages;

    //上一页

    $up_row = $this->nowPage - 1;

    $up_page = $up_row > 0 ? &#39;<li><a class="prev" href="&#39; . $this->url($up_row) . &#39;" rel="external nofollow" >&#39; . $this->config[&#39;prev&#39;] . &#39;</a></li>&#39; : &#39;&#39;;

    //下一页

    $down_row = $this->nowPage + 1;

    $down_page = ($down_row <= $this->totalPages) ? &#39;<li><a class="next" href="&#39; . $this->url($down_row) . &#39;" rel="external nofollow" >&#39; . $this->config[&#39;next&#39;] . &#39;</a></li>&#39; : &#39;&#39;;

    //第一页

    $the_first = &#39;&#39;;

    if($this->totalPages > $this->rollPage && ($this->nowPage - $now_cool_page) >= 1){

      $the_first = &#39;<li><a class="first" href="&#39; . $this->url(1) . &#39;" rel="external nofollow" >&#39; . $this->config[&#39;first&#39;] . &#39;</a></li>&#39;;

    }

    //最后一页

    $the_end = &#39;&#39;;

    if($this->totalPages > $this->rollPage && ($this->nowPage + $now_cool_page) < $this->totalPages){

      $the_end = &#39;<li><a class="end" href="&#39; . $this->url($this->totalPages) . &#39;" rel="external nofollow" >&#39; . $this->config[&#39;last&#39;] . &#39;</a></li>&#39;;

    }

    //数字连接

    $link_page = "";

    for($i = 1; $i <= $this->rollPage; $i++){

      if(($this->nowPage - $now_cool_page) <= 0 ){

        $page = $i;

      }elseif(($this->nowPage + $now_cool_page - 1) >= $this->totalPages){

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

      }else{

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

      }

      if($page > 0 && $page != $this->nowPage){

        if($page <= $this->totalPages){

          $link_page .= &#39;<li><a class="num" href="&#39; . $this->url($page) . &#39;" rel="external nofollow" >&#39; . $page . &#39;</a></li>&#39;;

        }else{

          break;

        }

      }else{

        if($page > 0 && $this->totalPages != 1){

          $link_page .= &#39;<li class="active "><span>&#39;.$page.&#39;<span class="sr-only"></span></span></li>&#39;;

        }

      }

    }

    //替换分页内容

    $page_str = str_replace(

      array(&#39;%HEADER%&#39;, &#39;%NOW_PAGE%&#39;, &#39;%UP_PAGE%&#39;, &#39;%DOWN_PAGE%&#39;, &#39;%FIRST%&#39;, &#39;%LINK_PAGE%&#39;, &#39;%END%&#39;, &#39;%TOTAL_ROW%&#39;, &#39;%TOTAL_PAGE%&#39;),

      array($this->config[&#39;header&#39;], $this->nowPage, $up_page, $down_page, $the_first, $link_page, $the_end, $this->totalRows, $this->totalPages),

      $this->config[&#39;theme&#39;]);

    return "<ul class=&#39;pagination&#39;>{$page_str}</ul>";

  }

}

Copier après la connexion
2. Le code

Contrôleur associé

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

//所有新闻

public function all_news(){

  $Article=M("Article");

  $where[&#39;article_type&#39;]=1;

  //查询满足要求的总的记录数

  $count=$Article->where($where)->count();

  //实例化分页类传入总记录数和煤业显示的记录数

  $Page=new \Think\Page($count,1);

  //分页显示输出

  $show=$Page->show();

  // 进行分页数据查询 注意limit方法的参数要使用Page类的属性

  $news=$Article->where($where)->order(&#39;pub_time&#39;)->field(&#39;id,title,institution_type,author_name,pub_time&#39;)->limit($Page->firstRow.&#39;,&#39;.$Page->listRows)->select();

  //赋值数据集

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

  //赋值分页输出

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

  $this->display();

}

Copier après la connexion
3.html ne nécessite que

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Vous avez un jeu croisé?
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment obtenir la barre de recherche bootstrap Comment obtenir la barre de recherche bootstrap Apr 07, 2025 pm 03:33 PM

Comment utiliser Bootstrap pour obtenir la valeur de la barre de recherche: détermine l'ID ou le nom de la barre de recherche. Utilisez JavaScript pour obtenir des éléments DOM. Obtient la valeur de l'élément. Effectuer les actions requises.

Comment faire le centrage vertical de bootstrap Comment faire le centrage vertical de bootstrap Apr 07, 2025 pm 03:21 PM

Utilisez Bootstrap pour implémenter Centering vertical: Flexbox Méthode: Utilisez les classes D-Flex, Justify-Content-Center et Align-Items-Center pour placer des éléments dans le conteneur Flexbox. Méthode de classe Align-Items-Center: Pour les navigateurs qui ne prennent pas en charge FlexBox, utilisez la classe Align-Items-Center, à condition que l'élément parent ait une hauteur définie.

Comment utiliser Bootstrap en Vue Comment utiliser Bootstrap en Vue Apr 07, 2025 pm 11:33 PM

L'utilisation de bootstrap dans vue.js est divisée en cinq étapes: installer bootstrap. Importer un bootstrap dans main.js. Utilisez le composant bootstrap directement dans le modèle. Facultatif: style personnalisé. Facultatif: utilisez des plug-ins.

Comment écrire des lignes fendues sur bootstrap Comment écrire des lignes fendues sur bootstrap Apr 07, 2025 pm 03:12 PM

Il existe deux façons de créer une ligne divisée bootstrap: en utilisant la balise, qui crée une ligne divisée horizontale. Utilisez la propriété CSS Border pour créer des lignes de fractionnement de style personnalisées.

Comment redimensionner le bootstrap Comment redimensionner le bootstrap Apr 07, 2025 pm 03:18 PM

Pour ajuster la taille des éléments dans Bootstrap, vous pouvez utiliser la classe de dimension, qui comprend: ajuster la largeur: .col-, .w-, .mw-ajustement Hauteur: .h-, .min-h-, .max-h-

Comment configurer le cadre de bootstrap Comment configurer le cadre de bootstrap Apr 07, 2025 pm 03:27 PM

Pour configurer le framework Bootstrap, vous devez suivre ces étapes: 1. Référez le fichier bootstrap via CDN; 2. Téléchargez et hébergez le fichier sur votre propre serveur; 3. Incluez le fichier bootstrap dans HTML; 4. Compiler les sass / moins au besoin; 5. Importer un fichier personnalisé (facultatif). Une fois la configuration terminée, vous pouvez utiliser les systèmes, composants et styles de grille de Bootstrap pour créer des sites Web et des applications réactifs.

Comment insérer des photos sur bootstrap Comment insérer des photos sur bootstrap Apr 07, 2025 pm 03:30 PM

Il existe plusieurs façons d'insérer des images dans Bootstrap: insérer directement les images, en utilisant la balise HTML IMG. Avec le composant d'image bootstrap, vous pouvez fournir des images réactives et plus de styles. Définissez la taille de l'image, utilisez la classe IMG-FLUID pour rendre l'image adaptable. Réglez la bordure en utilisant la classe IMG-border. Réglez les coins arrondis et utilisez la classe Roundée IMG. Réglez l'ombre, utilisez la classe Shadow. Redimensionner et positionner l'image, en utilisant le style CSS. À l'aide de l'image d'arrière-plan, utilisez la propriété CSS d'image d'arrière-plan.

Que faire si la table bootstrap utilise Ajax pour faire grimper les données Que faire si la table bootstrap utilise Ajax pour faire grimper les données Apr 07, 2025 am 11:54 AM

Solutions à la table Bootstrap Code Bootstrap lors de l'utilisation de AJAX pour obtenir des données à partir du serveur: 1. Définissez le codage de caractères correct du code côté serveur (tel que UTF-8). 2. Définissez l'en-tête de demande dans la demande AJAX et spécifiez le codage des caractères accepté (accepte-charge). 3. Utilisez le convertisseur "Unescape" de la table bootstrap pour décoder l'entité HTML échappée en caractères originaux.

See all articles