加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

Codeigniter(CI)框架分页函数及相关知识

发布时间:2020-12-13 02:07:09 所属栏目:PHP教程 来源:网络整理
导读:《:Codeigniter(CI)框架分页函数及相关知识》要点: 本文介绍了:Codeigniter(CI)框架分页函数及相关知识,希望对您有用。如果有疑问,可以联系我们。 PHP教程 一般在数据分页的时候必要获取当前页的数据和总条数,一般人是在model中封装两个函数分别获取当

《:Codeigniter(CI)框架分页函数及相关知识》要点:
本文介绍了:Codeigniter(CI)框架分页函数及相关知识,希望对您有用。如果有疑问,可以联系我们。

PHP教程一般在数据分页的时候必要获取当前页的数据和总条数,一般人是在model中封装两个函数分别获取当前页的数据和数据总条数,业务逻辑类似,感觉有点冗余,可以封装在一起:

代码如下:

/**
???? * 获取分页数据及总条数
???? * @param string @tablename 表名
???? * @param mixed $where 条件
???? * @param int $limit 每页条数
???? * @param int $offset 当前页
???? */
??? public function get_page_data($tablename,$where,$limit,$offset,$order_by,$db)
??? {
??????? if(empty($tablename))
??????? {
??????????? return FALSE;
??????? }
???????
??????? $dbhandle = empty($db) ? $this->db : $db;
???????
??????? if($where)
??????? {
??????????? if(is_array($where))
??????????? {
??????????????? $dbhandle->where($where);
??????????? }
??????????? else
??????????? {
??????????????? $dbhandle->where($where,NULL,false);
??????????? }
??????? }
???????
??????? $db = clone($dbhandle);
??????? $total = $dbhandle->count_all_results($tablename);
???????
??????? if($limit)
??????? {
??????????? $db->limit($limit);
??????? }
???????
??????? if($offset)
??????? {
??????????? $db->offset($offset);
??????? }
???????
??????? if($order_by)
??????? {
??????????? $db->order_by($order_by);
??????? }
???????
??????? $data = $db->get($tablename)->result_array();
???????
??????? return array('total' => $total,'data' => $data);
??? }

PHP教程CI框架分页类使用心得

PHP教程CI分页的url地址有四种方式
a) locahost/news/page/2 这个2表现第二页
b) localhost/news/page/20 这个20表现从第20条记录开始分页,即页面的第一条记录,是数据库中的第20条记录.
c) localhost/news?per_page=2 第二页
d) localhost/news?per_page=20 同b)

PHP教程首先我们先看一下CI分页的参数:

代码如下:

$config['base_url'] = $url;??
/* 分页的基础 URL
如果你想用a、b的链接形式,则该url应该形式如/news/page/?
如果链接是c、d的形式,则url应该如/news??
*/?
$config['total_rows'] = $total;//记录总数,这个没什么好说的了,就是你从数据库取得记录总数??
$config['per_page'] = $pagesize; //每页条数.额,这个也没什么好说的..本身设定.默认为10好像.??
$config['page_query_string'] = TRUE;??
/*传参形式.开启true则会自动在你的url后面加上&per_page=3.(这个per_page是默认的查询字符,当然你也可以用$config['query_string_segment']来本身设定)
因此c、d中的形式一般是为localhost/news?&per_page=2不过都一样,没什么影响.get的per_page还是3?
*/?
$config['first_link'] = '首页'; // 第一页显示??
$config['last_link'] = '末页'; // 最后一页显示??
$config['next_link'] = '下一页 >'; // 下一页显示??
$config['prev_link'] = '< 上一页'; // 上一页显示??
$config['cur_tag_open'] = ' <a class="current">'; // 当前页开始样式??
$config['cur_tag_close'] = '</a>';??
/*当前页结束样式.这些你可以本身尝试一下.
比如说我想让当前页的分页数字样式好看一点,红色字体等.你就可以在current上加上css代码?
*/?
$config['num_links'] = 2;// 当前连接前后显示页码个数.意思就是说你当前页是第5页,那么你可以看到3、4、5、6、7页.??
$config['uri_segment'] = 4;??
/*这个是你在用a)、b)链接样式的时候,用来判断页页数.
比如localhost/news/page/3? 这个uri_segment就要设定为3.localhost/news/title/page/3这个就要设定为4?
*/?
$config['use_page_numbers'] = TRUE;??
/*这个就是a)、b)的差别了.开启了,page就会表示页数.false就会表示记录数
*/?

PHP教程刚开始在网上查资料的时候,有很多这种写法.

代码如下:

$this->model->get_news($config['per_page'],$this->uri->segment(3));?

PHP教程其实这种写法便是针对b)这种连接形式的.这里的$this->uri->segment(3)便是取到page/20中的记录数20.$config['per_page']便是限制输出多少条.
有很大的局限性和误导性.我开始便是死都不知道为什么这么写..后来才发现,手册才是最好的老师.

PHP教程当我们把CI分页类的一些参数都配置好了之后,$this->pagination->initialize($config);//配置分页

代码如下:

$page = $this->pagination->create_links();? //我们就获得了分页了?

PHP教程直接传递到视图页,即可.

PHP教程至于怎么加载模型,怎么存取数据记录,怎么传递变量到视图,这里就不说了,看手册好了.

PHP教程忘记说了,带查询参数的分页,我是这么做的.视图中将查询参数get提交到控制器的search办法.在search中,用$get = $this->input->get();去获取到查询参数.
然后加载model,用带查询参数和分页参数去读取记录,将结果显示到视图..

PHP教程另外还发现个小bug,好比/news/page/-1000这样的时候,下面的分页链接将会出现负值
发现system/libraries/Pagination.php代码如下

代码如下:

if ($this->use_page_numbers AND $this->cur_page == 0)??
{??
??? $this->cur_page = $base_page;??
}??
//应为??
if ($this->use_page_numbers AND $this->cur_page <= 0)??
{??
??? $this->cur_page = $base_page;??
}?

PHP教程才对吧,颠末修改后,这个问题没有了.

《:Codeigniter(CI)框架分页函数及相关知识》是否对您有启发,欢迎查看更多与《:Codeigniter(CI)框架分页函数及相关知识》相关教程,学精学透。编程之家 52php.cn为您提供精彩教程。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读