如何在 Codeigniter 分页中使用页码而不是偏移量?

Posted

技术标签:

【中文标题】如何在 Codeigniter 分页中使用页码而不是偏移量?【英文标题】:How to use page numbers in Codeigniter pagination instead of offset? 【发布时间】:2012-07-13 20:17:33 【问题描述】:

我已阅读有关 *** 的所有问题,但没有看到该问题的明确答案。我目前正在使用 codeigniter 分页库使用限制和偏移量生成我的分页链接:

$config['base_url'] = base_url() . 'explore/featured/index/';
    $config['total_rows'] = $this->Projects_model->get_featured_count();//Count featured projects
    $config['per_page'] = 12;
    $config['uri_segment'] = 4;
    $config['display_pages'] = FALSE;
    $config['next_link'] = 'Older →';
    $config['prev_link'] = '← Newer';
    $this->pagination->initialize($config);
    $limit = $config['per_page'];
    $offset = $this->uri->segment(4);

    $data['pagination'] = $this->pagination->create_links();

    $data['projects'] = $this->Projects_model->get_featured($limit, $offset); //get featured projects from database

上述代码限制了我的查询的输出值,并使用了我的第 4 个 URI 段中包含的偏移量。

如何将以下代码更改为页码???似乎是不可能的,因为我将无法再在我的网址中使用偏移量。

【问题讨论】:

【参考方案1】:

在某个时候,CI 更新了他们的 pagination library 以(最终)适应这一点:

$config['use_page_numbers'] = TRUE; 默认情况下,URI 段将 使用您正在分页的项目的起始索引。如果你比较喜欢 要显示实际的页码,请将其设置为 TRUE。

如果您使用的版本没有此功能并且无法更新整个 CI 安装,您应该可以直接放入最新的分页库。

要计算您的数据库偏移量,请使用$limit * $page_number,其中“page_number”是您的 URL 中的值(在您的情况下是第 4 段)。

【讨论】:

“在某些时候” === 2.10 版于 2011 年 11 月 14 日发布。我很久以前就放弃了他们的分页库,我没有意识到他们做出了改变。您可能已经在使用它了。 你用的是什么?只是好奇。【参考方案2】:

上面提到的$limit * $page_number 没有返回真正的偏移量作为起点,当页码为 1 时会产生问题,因为此时偏移量必须为 0。这对我有用:

$offset = ($page_number  == 1) ? 0 : ($page_number * $config['per_page']) - $config['per_page'];

【讨论】:

如果有人想使用它,就想把它放在这里。如果您从段中获取页码,只需对第一个条件进行额外检查:($page_number == 1 || $page_number == NULL)。这对我的程序有用,感谢您分享答案,真的很有帮助:)【参考方案3】:

只需使用:

$offset = ($this->uri->segment(4)) ? $this->uri->segment(4) : 1;
$data['projects'] = $this->Projects_model->get_featured($limit, $limit*($offset-1));

【讨论】:

请添加一些解释。 是的,我的英语不好,所以希望你能理解。例如:您的限制是 4 个帖子。在第 1 页(偏移量 = 空,因此默认情况下它将获得值“1”),模型将从 0 (limit*(offset-1) = 0) 到您的限制 (4) 进行选择。第 2 页 (offset=2) 相同,它将从 4 (limit*(offset-1) = 4) 到您的限制 (4) 中选择。这样每个页面都有 4 个您想要的帖子。【参考方案4】:
$page_num = $this->uri->segment(1);
$offset = ($page_num  == NULL) ? 0 : 
          ($page_num * $config['per_page']) - $config['per_page'];

【讨论】:

以上是关于如何在 Codeigniter 分页中使用页码而不是偏移量?的主要内容,如果未能解决你的问题,请参考以下文章

如何使用 codeigniter 分页库回显页码?

如何在分页中获取特定行的页码

在使用 graphql 缓存的基于游标的分页中跟踪页码

在 Jquery carouFredSel 分页中需要下一个和最后一个链接隐藏在页码 X 之后

在codeigniter中搜索所有分页链接的分页

codeigniter 分页首页 URL