PHP CodeIgniter分页实例及多条件查询解决方案(推荐)

5年以前  |  阅读数:343 次  |  编程语言:PHP 

最近在用CI框架的时候,用了CI的分页类,以前是用前端整分页,这次干脆用用框架自带的,自己这个健忘的脑袋,还是记录一下吧。

因为页面中有条件筛选的表单,所以想要完成的效果就是,输入条件后,分页跳转之后能维持所输入的条件。想了一下,自己的思路如下代码吧。

controller 代码


    class Monitors extends CI_Controller {
    public function warning(){
        $config= array();
        $config['per_page'] = 15; //每页显示的数据数
        $current_page = intval($this->input->get("per_page")); //获取当前分页页码数

     $status=$this->input->get("filter-status",TRUE);
     $level=$this->input->get('filter-level',TRUE);
     $timestamp=$this->input->get('filter-timestamp',TRUE);
        $all = $this->monitors_m->getAllData($current_page,$config['per_page'],$status,$timestamp,$level);
       //这里返回的有总条数和具体的数据,根据自己的情况略加修改即可
     $data['allevent'] = $all['content'];
     $config['total_rows']   = $all['count'];//总条数
        $config['num_links'] = 3;//页码连接数
     $config['use_page_numbers'] = TRUE; 
     $config['page_query_strings'] = TRUE;//关键配置
     $config['base_url'] = base_url().'index.php/monitors/warning?'&filter-status;='.$status.'&filter-level;='.$level.'&filter-timestamp;='.$timestamp;//关键配置
     $this->load->library('pagination');//加载ci pagination类
     $this->pagination->initialize($config);
     $data['page'] = $this->pagination->create_links();//关键代码
     $this->load->view("monitors_v",$data);
    }

关键配置参数


    $config['page_query_string']

如果设置成true,则url则是"index.php/monitors/warning?per_page=20"这样的

【注】"per_page" 是默认传递的查询字符串,但也可以使用 $config['query_string_segment'] = '你的字符串' 来配置

在我的方案中,设置为TRUE,当然TRUE是默认值,不管也可以;


    $config['base_url']

一开始只是设置为以下这种情况的时候,在某一页进行条件筛选是可以的,但是跳转后由于刷新的问题条件又没有了。


    $config['base_url'] = base_url().'index.php/monitors/warning;

采用以下的方式即可,吼吼吼


    $status=$this->input->get("filter-status",TRUE);
    $level=$this->input->get('filter-level',TRUE);
    $timestamp=$this->input->get('filter-timestamp',TRUE);
    $config['base_url'] = base_url().'index.php/monitors/warning?'&filter-status;='.$status.'&filter-level;='.$level.'&filter-timestamp;='.$timestamp;//关键配置

view页面代码

就一句话,在你需要放置分页元素的地方加上这样一句就行,这里的$page变量就是在controller里存进去的$this->pagination->create_links();


    <?php echo $page?>

设置分页样式

这里采用的是bootstrap的样式


    $config['first_link']   = "<<";//首页
    $config['prev_link']   = "<";//上一页
    $config['next_link']   = ">";//下一页
    $config['last_link']   = ">>";//尾页
    $config['full_tag_open'] = '<ul class="pagination pagination-split">'; 
    $config['full_tag_close'] = '</ul>'; 
    $config['first_tag_open'] = '<li>';//第一个链接的起始标签。
    $config['first_tag_close'] = '</li>';//第一个链接的结束标签。
    $config['next_tag_open'] = '<li>';//下一页链接的起始标签。
    $config['next_tag_close'] = '</li>';//下一页链接的结束标签。
    $config['prev_tag_open'] = '<li>';//上一页链接的起始标签。
    $config['prev_tag_close'] = '</li>';//上一页链接的结束标签。
    $config['cur_tag_open'] = '<li class="active"><a>';
    $config['cur_tag_close'] = '</a></li>';//当前页链接的结束标签。
    $config['num_tag_open'] = '<li>';//数字链接的起始标签。
    $config['num_tag_close'] = '</li>';//数字链接的结束标签。

以上所述是小编给大家介绍的PHP CodeIgniter分页实例及多条件查询解决方案,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的,在此也非常感谢大家对脚本之家网站的支持!

 相关文章:
PHP分页显示制作详细讲解
SSH 登录失败:Host key verification failed
获取IMSI
将二进制数据转为16进制以便显示
获取IMEI
文件下载
贪吃蛇
双位运算符
PHP自定义函数获取搜索引擎来源关键字的方法
Java生成UUID
发送邮件
年的日历图
提取后缀名
在Zeus Web Server中安装PHP语言支持
让你成为最历害的git提交人
Yii2汉字转拼音类的实例代码
再谈PHP中单双引号的区别详解
指定应用ID以获取对应的应用名称
Python 2与Python 3版本和编码的对比
php封装的page分页类完整实例