thinkphp5+layui实现的分页样式示例

吾爱主题 阅读:160 2021-08-26 14:33:00 评论:0

本文实例讲述了thinkphp5+layui实现的分页样式。分享给大家供大家参考,具体如下:

tp5之layui分页样式

1.分页类

路径:\thinkphp\library\think\paginator\driver

Layui.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 <?php namespace think\paginator\driver; use think\Paginator; class Layui extends Paginator {    /**     * 上一页按钮     * @param string $text     * @return string     */    protected function getPreviousButton( $text = "上一页" )    {      if ( $this ->currentPage() <= 1) {        return $this ->getDisabledTextWrapper( $text );      }      $url = $this ->url(        $this ->currentPage() - 1      );      return $this ->getPageLinkWrapper( $url , $text );    }    /**     * 下一页按钮     * @param string $text     * @return string     */    protected function getNextButton( $text = '下一页' )    {      if (! $this ->hasMore) {        return $this ->getDisabledTextWrapper( $text );      }      $url = $this ->url( $this ->currentPage() + 1);      return $this ->getPageLinkWrapper( $url , $text );    }    /**     * 页码按钮     * @return string     */    protected function getLinks()    {      if ( $this ->simple)        return '' ;      $block = [        'first' => null,        'slider' => null,        'last'  => null      ];      $side  = 3;      $window = $side * 2;      if ( $this ->lastPage < $window + 6) {        $block [ 'first' ] = $this ->getUrlRange(1, $this ->lastPage);      } elseif ( $this ->currentPage <= $window ) {        $block [ 'first' ] = $this ->getUrlRange(1, $window + 2);        $block [ 'last' ] = $this ->getUrlRange( $this ->lastPage - 1, $this ->lastPage);      } elseif ( $this ->currentPage > ( $this ->lastPage - $window )) {        $block [ 'first' ] = $this ->getUrlRange(1, 2);        $block [ 'last' ] = $this ->getUrlRange( $this ->lastPage - ( $window + 2), $this ->lastPage);      } else {        $block [ 'first' ] = $this ->getUrlRange(1, 2);        $block [ 'slider' ] = $this ->getUrlRange( $this ->currentPage - $side , $this ->currentPage + $side );        $block [ 'last' ]  = $this ->getUrlRange( $this ->lastPage - 1, $this ->lastPage);      }      $html = '' ;      if ( is_array ( $block [ 'first' ])) {        $html .= $this ->getUrlLinks( $block [ 'first' ]);      }      if ( is_array ( $block [ 'slider' ])) {        $html .= $this ->getDots();        $html .= $this ->getUrlLinks( $block [ 'slider' ]);      }      if ( is_array ( $block [ 'last' ])) {        $html .= $this ->getDots();        $html .= $this ->getUrlLinks( $block [ 'last' ]);      }      return $html ;    }    /**     * 渲染分页html     * @return mixed     */    public function render()    {      if ( $this ->hasPages()) {        if ( $this ->simple) {          return sprintf(            '<ul class="pager">%s %s</ul>' ,            $this ->getPreviousButton(),            $this ->getNextButton()          );        } else {          return sprintf(            '%s %s %s' ,            $this ->getPreviousButton(),            $this ->getLinks(),            $this ->getNextButton()          );        }      }    }    /**     * 生成一个可点击的按钮     *     * @param string $url     * @param int  $page     * @return string     */    protected function getAvailablePageWrapper( $url , $page )    {      return '<a href="' . htmlentities( $url ) . '" rel="external nofollow" >' . $page . '</a>' ;    }    /**     * 生成一个禁用的按钮     *     * @param string $text     * @return string     */    protected function getDisabledTextWrapper( $text )    {      return '<a class="layui-laypage-prev" >' . $text . '</a>' ;    }    /**     * 生成一个激活的按钮     *     * @param string $text     * @return string     */    protected function getActivePageWrapper( $text )    {      return '<span class="layui-laypage-curr"> <em class="layui-laypage-em"></em><em>' . $text . '</em></span>' ;    }    /**     * 生成省略号按钮     *     * @return string     */    protected function getDots()    {      return $this ->getDisabledTextWrapper( '...' );    }    /**     * 批量生成页码按钮.     *     * @param array $urls     * @return string     */    protected function getUrlLinks( array $urls )    {      $html = '' ;      foreach ( $urls as $page => $url ) {        $html .= $this ->getPageLinkWrapper( $url , $page );      }      return $html ;    }    /**     * 生成普通页码按钮     *     * @param string $url     * @param int  $page     * @return string     */    protected function getPageLinkWrapper( $url , $page )    {      if ( $page == $this ->currentPage()) {        return $this ->getActivePageWrapper( $page );      }      return $this ->getAvailablePageWrapper( $url , $page );    } }

2.配置文件

paginate.php

?
1 2 3 4 5 6 7 8 9 10 11 <?php /**   * @auther: xxf   * Date: 2019/9/2   * Time: 10:24   */ //分页配置 return [    'type' => 'Layui' ,    'var_page' => 'page' , ];

3.模型查询

?
1 2 3 4 5 6 7 8 9 public function getUserShowList( $size = 20, $where = null) {      $res = $this        ->field( 'id,title,list_order,is_top,create_time,create_time time' )        ->where( $where )        ->order([ 'is_top' => 'desc' , 'list_order' => 'desc' , 'id' => 'desc' ])        ->paginate( $size );      return $res ; }

4.模板渲染

?
1 < div class = "layui-box layui-laypage layui-laypage-molv" >{$list|raw}</ div >

效果

希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。

原文链接:https://blog.csdn.net/flysnownet/article/details/100247490

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容