通用分页类
通用分页类(以Codeigniter测试) CodeIgniter ?php if( ! defined('BASEPATH')) die('No Access');/** * 分页类 * * @author wangaibowangaibo@boqii.net * @version 1.0.0 * @link http://www.du52.com/text.php?id=551 */class Page_list { /** * 总数据 *
通用分页类(以Codeigniter测试) CodeIgniter
<?php if( ! defined('BASEPATH')) die('No Access'); /** * 分页类 * * @author wangaibo<wangaibo@boqii.net> * @version 1.0.0 * @link http://www.du52.com/text.php?id=551 */ class Page_list { /** * 总数据 * @var int */ private $total; /** * 每页显示数据 * @var int */ private $size; /** * 当前页数 * @var int */ private $page; /** * 页数列表左右页数 * @var int */ private $len; /** * 总页数 * @var int */ private $page_total; /** * 页码列表 * @var array */ private $page_list; /** * 基准地址 * @var string */ private $base_url; /** * 替换标志 * @var string */ private $place; /** * 分页样式 * @var string */ private $style; /** * 构造函数 * * @param array $config 配置数组 */ public function __construct($config = array()){ // 初始化默认值 $this->total = 0; $this->size = 20; $this->page = 1; $this->len = 4; $this->page_total = 1; $this->page_list = array(); $this->base_url = '?page=-page-'; $this->place = '-page-'; $this->style = $this->get_default_style(); $this->initialize($config); } /** * 初始化分页 * * @param array $config 配置数组 */ public function initialize($config = array()){ // 取得配置值 if(is_array($config)){ if(array_key_exists('total', $config)) $this->total = @intval($config['total']); if(array_key_exists('size', $config)) $this->size = @intval($config['size']); if(array_key_exists('page', $config)) $this->page = @intval($config['page']); if(array_key_exists('len', $config)) $this->len = @intval($config['len']); if(array_key_exists('base_url', $config)) $this->base_url = @strval($config['base_url']); if(array_key_exists('place', $config)) $this->place = @strval($config['place']); if(array_key_exists('style', $config)) $this->style = @strval($config['style']); } // 修正值 if($this->total<0) $this->total = 0; if($this->size<=0) $this->size = 20; if($this->page<=0) $this->page = 1; if($this->len<=0) $this->len = 4; // 执行分页算法 $this->page_total = ceil($this->total/$this->size); if($this->page_total<=0) $this->page_total = 1; if($this->page>$this->page_total) $this->page = $this->page_total; if($this->page-$this->len>=1){ for($i=$this->len; $i>0; $i--){ $this->page_list[] = $this->page - $i; } }else{ for($i=1; $i<$this->page; $i++){ $this->page_list[] = $i; } } $this->page_list[] = $this->page; if($this->page+$this->len<=$this->page_total){ for($i=1; $i<=$this->len; $i++){ $this->page_list[] = $this->page + $i; } }else{ for($i=$this->page+1; $i<=$this->page_total; $i++){ $this->page_list[] = $i; } } } /** * 默认分页样式 * * @return string */ public function get_default_style(){ $style = '<style type="text/css">'; $style .= ' div.page_list { margin:0;padding:0;overflow:hidden;zoom:1;}'; $style .= ' div.page_list a {display:block;float:left;height:20px;line-height:21px; font-size:13px;font-weight:normal;font-style:normal;color:#133DB6;text-decoration:none;margin:0 3px;padding:0 7px;overflow;zoom:1;}'; $style .= ' div.page_list a.page_list_act { font-size:13px;padding:0 6px;}'; $style .= ' div.page_list a:link, div.page_list a:visited { background:#FFF;border:1px #EEE solid;text-decoration:none;}'; $style .= ' div.page_list a:hover, div.page_list a:active { background:#EEE;text-decoration:none;}'; $style .= ' div.page_list strong { display:block;float:left;height:20px;line-height:21px;font-size:13px;font-weight:bold;font-style:normal;color:#000;margin:0 3px;padding:0 8px;overflow:hidden;zoom:1;}'; $style .= ' </style>'; return $style; } /** * 是否是第一页 * * @return bool */ public function is_first_page(){ return $this->page == 1; } /** * 获取第一页页码 * * @return int */ public function get_first_page(){ return 1; } /** * 是否是最后一页 * * @return bool */ public function is_last_page(){ return $this->page == $this->page_total; } /** * 获取最后一页页码 * * @return int */ public function get_last_page(){ return $this->page_total; } /** * 是否存在上一页 * * @return bool */ public function has_prev_page(){ return $this->page > 1; } /** * 是否存在下一页 * * @return bool */ public function has_next_page(){ return $this->page < $this->page_total; } /** * 获取上一页页码 * * @return int */ public function get_prev_page(){ return $this->has_prev_page() ? $this->page - 1 : $this->page; } /** * 获取下一页页码 * * @return int */ public function get_next_page(){ return $this->has_next_page() ? $this->page + 1 : $this->page; } /** * 获取当前页页码 * * @return int */ public function get_curr_page(){ return $this->page; } /** * 获取总数据数 * * @return int */ public function get_total(){ return $this->total; } /** * 获取每页显示数据数 * * @return int */ public function get_size(){ return $this->size; } /** * 获取总页数 * * @return int */ public function get_total_page(){ return $this->page_total; } /** * 构建并返回分页代码 * * @param string $base_url 基准地址 * @param string $place 替换标志 * @param string $style 分页样式 * @return string 分页HTML代码 */ public function display($base_url = '', $place = '', $style = ''){ if($base_url==='') $base_url = $this->base_url; if($place==='') $place = $this->place; if($style==='') $style = $this->style; $str = $style.'<div class="page_list">'; if( ! $this->is_first_page()){ $str .= '<a class="page_list_act" href="'.str_replace($place, $this->get_first_page(), $base_url).'">首页</a>'; } if($this->has_prev_page()){ $str .= '<a class="page_list_act" href="'.str_replace($place, $this->get_prev_page(), $base_url).'">上一页</a>'; } foreach($this->page_list as $v){ if($v==$this->page){ $str .= '<strong>' . $v . '</strong>'; }else{ $str .= '<a href="'.str_replace($place, $v, $base_url).'">'.$v.'</a>'; } } if($this->has_next_page()){ $str .= '<a class="page_list_act" href="'.str_replace($place, $this->get_next_page(), $base_url).'">下一页</a>'; } if( ! $this->is_last_page()){ $str .= '<a class="page_list_act" href="'.str_replace($place, $this->get_last_page(), $base_url).'">尾页</a>'; } $str .= '</div>'; return $str; } } ?>
<?php if( ! defined('BASEPATH')) die('No Access'); class Pagelist extends CI_Controller { public function page(){ $this->load->helper('url'); $page = $this->input->get('page'); $page = @intval($page); if($page<=0) $page = 1; $this->load->library('page_list',array('total'=>10000,'size'=>16,'page'=>$page)); $pl = $this->page_list->display(site_url('pagelist/page/page/-page-')); $this->load->view('pagelist', array('pl' => $pl)); } } ?>
<!DOCTYPE html> <html> <head> <meta http-equiv="content-type" content="text/html;charset=utf-8" /> <title>分页测试</title> </head> <body> <?php echo $pl; ?> </body> </html>


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



What do you think of furmark? 1. Set the "Run Mode" and "Display Mode" in the main interface, and also adjust the "Test Mode" and click the "Start" button. 2. After waiting for a while, you will see the test results, including various parameters of the graphics card. How is furmark qualified? 1. Use a furmark baking machine and check the results for about half an hour. It basically hovers around 85 degrees, with a peak value of 87 degrees and room temperature of 19 degrees. Large chassis, 5 chassis fan ports, two on the front, two on the top, and one on the rear, but only one fan is installed. All accessories are not overclocked. 2. Under normal circumstances, the normal temperature of the graphics card should be between "30-85℃". 3. Even in summer when the ambient temperature is too high, the normal temperature is "50-85℃

PHP development: How to implement table data sorting and paging functions In web development, processing large amounts of data is a common task. For tables that need to display a large amount of data, it is usually necessary to implement data sorting and paging functions to provide a good user experience and optimize system performance. This article will introduce how to use PHP to implement the sorting and paging functions of table data, and give specific code examples. The sorting function implements the sorting function in the table, allowing users to sort in ascending or descending order according to different fields. The following is an implementation form

The "Inaction Test" of the new fantasy fairy MMORPG "Zhu Xian 2" will be launched on April 23. What kind of new fairy adventure story will happen in Zhu Xian Continent thousands of years after the original work? The Six Realm Immortal World, a full-time immortal academy, a free immortal life, and all kinds of fun in the immortal world are waiting for the immortal friends to explore in person! The "Wuwei Test" pre-download is now open. Fairy friends can go to the official website to download. You cannot log in to the game server before the server is launched. The activation code can be used after the pre-download and installation is completed. "Zhu Xian 2" "Inaction Test" opening hours: April 23 10:00 - May 6 23:59 The new fairy adventure chapter of the orthodox sequel to Zhu Xian "Zhu Xian 2" is based on the "Zhu Xian" novel as a blueprint. Based on the world view of the original work, the game background is set

How to use JavaScript to implement table paging function? With the development of the Internet, more and more websites use tables to display data. In some cases where the amount of data is large, the data needs to be displayed in pages to improve user experience. This article will introduce how to use JavaScript to implement table paging function and provide specific code examples. 1. HTML structure First, we need to prepare an HTML structure to host tables and paging buttons. We can use <tab

"Operation Delta" will launch a large-scale PC test called "Codename: ZERO" today (March 7). Last weekend, this game held an offline flash mob experience event in Shanghai, and 17173 was also fortunate to be invited to participate. This test is only more than four months away from the last time, which makes us curious, what new highlights and surprises will "Operation Delta" bring in such a short period of time? More than four months ago, I experienced "Operation Delta" in an offline tasting session and the first beta version. At that time, the game only opened the "Dangerous Action" mode. However, Operation Delta was already impressive for its time. In the context of major manufacturers flocking to the mobile game market, such an FPS that is comparable to international standards

MyBatis is an excellent persistence layer framework. It supports database operations based on XML and annotations. It is simple and easy to use. It also provides a rich plug-in mechanism. Among them, the paging plug-in is one of the more frequently used plug-ins. This article will delve into the principles of the MyBatis paging plug-in and illustrate it with specific code examples. 1. Paging plug-in principle MyBatis itself does not provide native paging function, but you can use plug-ins to implement paging queries. The principle of paging plug-in is mainly to intercept MyBatis

How to use Layui to develop a data display page with paging function Layui is a lightweight front-end UI framework that provides simple and beautiful interface components and a rich interactive experience. During development, we often encounter situations where we need to display large amounts of data and perform paging. The following is an example of a data display page with paging function developed using Layui. First, we need to introduce Layui related files and dependencies. Add the following code to the <head> tag of the html page

Vue component practice: Introduction to paging component development In web applications, the paging function is an essential component. A good paging component should be simple and clear in presentation, rich in functions, and easy to integrate and use. In this article, we will introduce how to use the Vue.js framework to develop a highly customizable paging component. We will explain in detail how to develop using Vue components through code examples. Technology stack Vue.js2.xJavaScript (ES6) HTML5 and CSS3 development environment
