如何更改 Codeigniter create_links() 生成的链接结构?
How can I change the structure of the links that Codeigniter create_links() generates?
我正在开发一个小型博客应用程序。它的后端和前端之间有明显的分离:
- 后端是一个 API,用 Codeigniter 3 制作,吐出
页面、帖子、分页等
- 此 API 由 AngularJS (v. 1.7.x) 前端使用;
前端帖子控制器如下所示:
// All posts
.controller('PostsController', ['$scope', '$http', function($scope, $http){
//Get current page (?page=2, ?page=3 etc)
const currPage = window.location.search;
// Get all the posts on the current page
$http.get('api/' + currPage).then(function(response) {
// Posts
$scope.posts = response.data.posts;
// posts pagination
$scope.pagination = response.data.pagination;
});
}])
我对 Codeigniter (API) 生成的分页有疑问,这是因为它的根是 http://apiblog.com/api/
。分页的HTML是这样的:
<ul class="pagination">
<li><a href="http://apiblog.com/api/" data-ci-pagination-page="1" rel="prev">‹</a></li>
<li><a href="http://apiblog.com/api/" data-ci-pagination-page="1" rel="start">1</a></li>
<li class="active"><span>2</span></li>
<li><a href="http://apiblog.com/api/?page=3" data-ci-pagination-page="3">3</a></li>
<li><a href="http://apiblog.com/api/?page=4" data-ci-pagination-page="4">4</a></li>
<li><a href="http://apiblog.com/api/?page=3" data-ci-pagination-page="3" rel="next">›</a></li>
</ul>
通过查看前端帖子控制器,您可以看到分页链接应该 缺少 api/
部分。 应该是:
<ul class="pagination">
<li><a href="http://apiblog.com/" data-ci-pagination-page="1" rel="prev">‹</a></li>
<li><a href="http://apiblog.com/" data-ci-pagination-page="1" rel="start">1</a></li>
<li class="active"><span>2</span></li>
<li><a href="http://apiblog.com/?page=3" data-ci-pagination-page="3">3</a></li>
<li><a href="http://apiblog.com/?page=4" data-ci-pagination-page="4">4</a></li>
<li><a href="http://apiblog.com/?page=3" data-ci-pagination-page="3" rel="next">›</a></li>
</ul>
在帖子控制器中,负责在前端显示和分页帖子:
private function _initPagination($path, $totalRows, $query_string_segment = 'page') {
//load and configure pagination
$this->load->library('pagination');
$config['base_url'] = base_url($path);
$config['query_string_segment'] = $query_string_segment;
$config['enable_query_strings'] =TRUE;
$config['reuse_query_string'] =TRUE;
$config['total_rows'] = $totalRows;
$config['per_page'] = 12;
if (!isset($_GET[$config['query_string_segment']]) || $_GET[$config['query_string_segment']] < 1) {
$_GET[$config['query_string_segment']] = 1;
}
$this->pagination->initialize($config);
$limit = $config['per_page'];
$offset = ($this->input->get($config['query_string_segment']) - 1) * $limit;
return ['limit' => $limit, 'offset' => $offset];
}
public function index() {
//call initialization method
$config = $this->_initPagination("/", $this->Posts_model->get_num_rows());
$data = $this->Static_model->get_static_data();
//$data['pagination'] = $this->pagination->get_as_array();
$data['pagination'] = $this->pagination->create_links();
$data['pages'] = $this->Pages_model->get_pages();
$data['categories'] = $this->Categories_model->get_categories();
//use limit and offset returned by _initPaginator method
$data['posts'] = $this->Posts_model->get_posts($config['limit'], $config['offset']);
// All posts
$this->output->set_content_type('application/json')->set_output(json_encode($data, JSON_PRETTY_PRINT));
}
在后端(仪表板)中,帖子的代码是:
public function index() {
//load and configure pagination
$this->load->library('pagination');
$config['base_url'] = base_url("/dashboard/posts");
$config['query_string_segment'] = 'page';
$config['total_rows'] = $this->Posts_model->get_num_rows();
$config['per_page'] = 10;
if (!isset($_GET[$config['query_string_segment']]) || $_GET[$config['query_string_segment']] < 1) {
$_GET[$config['query_string_segment']] = 1;
}
$limit = $config['per_page'];
$offset = ($this->input->get($config['query_string_segment']) - 1) * $limit;
$this->pagination->initialize($config);
$data = $this->get_data();
$data['posts'] = $this->Posts_model->get_posts($limit, $offset);
$data['offset'] = $offset;
$this->load->view('partials/header', $data);
$this->load->view('dashboard/posts');
$this->load->view('partials/footer');
}
鉴于分页项是由 $data['pagination'] = $this->pagination->create_links();
生成的 "behind the scenes",我无法实现分页链接的必要配置。
我怎样才能做到这一点?
在您的 _initPagination
中,您有以下代码行
$config['base_url'] = base_url($path);
你可以把上面的改成
$config['base_url'] = "http://".$_SERVER['HTTP_HOST'] . $path;
我正在开发一个小型博客应用程序。它的后端和前端之间有明显的分离:
- 后端是一个 API,用 Codeigniter 3 制作,吐出 页面、帖子、分页等
- 此 API 由 AngularJS (v. 1.7.x) 前端使用;
前端帖子控制器如下所示:
// All posts
.controller('PostsController', ['$scope', '$http', function($scope, $http){
//Get current page (?page=2, ?page=3 etc)
const currPage = window.location.search;
// Get all the posts on the current page
$http.get('api/' + currPage).then(function(response) {
// Posts
$scope.posts = response.data.posts;
// posts pagination
$scope.pagination = response.data.pagination;
});
}])
我对 Codeigniter (API) 生成的分页有疑问,这是因为它的根是 http://apiblog.com/api/
。分页的HTML是这样的:
<ul class="pagination">
<li><a href="http://apiblog.com/api/" data-ci-pagination-page="1" rel="prev">‹</a></li>
<li><a href="http://apiblog.com/api/" data-ci-pagination-page="1" rel="start">1</a></li>
<li class="active"><span>2</span></li>
<li><a href="http://apiblog.com/api/?page=3" data-ci-pagination-page="3">3</a></li>
<li><a href="http://apiblog.com/api/?page=4" data-ci-pagination-page="4">4</a></li>
<li><a href="http://apiblog.com/api/?page=3" data-ci-pagination-page="3" rel="next">›</a></li>
</ul>
通过查看前端帖子控制器,您可以看到分页链接应该 缺少 api/
部分。 应该是:
<ul class="pagination">
<li><a href="http://apiblog.com/" data-ci-pagination-page="1" rel="prev">‹</a></li>
<li><a href="http://apiblog.com/" data-ci-pagination-page="1" rel="start">1</a></li>
<li class="active"><span>2</span></li>
<li><a href="http://apiblog.com/?page=3" data-ci-pagination-page="3">3</a></li>
<li><a href="http://apiblog.com/?page=4" data-ci-pagination-page="4">4</a></li>
<li><a href="http://apiblog.com/?page=3" data-ci-pagination-page="3" rel="next">›</a></li>
</ul>
在帖子控制器中,负责在前端显示和分页帖子:
private function _initPagination($path, $totalRows, $query_string_segment = 'page') {
//load and configure pagination
$this->load->library('pagination');
$config['base_url'] = base_url($path);
$config['query_string_segment'] = $query_string_segment;
$config['enable_query_strings'] =TRUE;
$config['reuse_query_string'] =TRUE;
$config['total_rows'] = $totalRows;
$config['per_page'] = 12;
if (!isset($_GET[$config['query_string_segment']]) || $_GET[$config['query_string_segment']] < 1) {
$_GET[$config['query_string_segment']] = 1;
}
$this->pagination->initialize($config);
$limit = $config['per_page'];
$offset = ($this->input->get($config['query_string_segment']) - 1) * $limit;
return ['limit' => $limit, 'offset' => $offset];
}
public function index() {
//call initialization method
$config = $this->_initPagination("/", $this->Posts_model->get_num_rows());
$data = $this->Static_model->get_static_data();
//$data['pagination'] = $this->pagination->get_as_array();
$data['pagination'] = $this->pagination->create_links();
$data['pages'] = $this->Pages_model->get_pages();
$data['categories'] = $this->Categories_model->get_categories();
//use limit and offset returned by _initPaginator method
$data['posts'] = $this->Posts_model->get_posts($config['limit'], $config['offset']);
// All posts
$this->output->set_content_type('application/json')->set_output(json_encode($data, JSON_PRETTY_PRINT));
}
在后端(仪表板)中,帖子的代码是:
public function index() {
//load and configure pagination
$this->load->library('pagination');
$config['base_url'] = base_url("/dashboard/posts");
$config['query_string_segment'] = 'page';
$config['total_rows'] = $this->Posts_model->get_num_rows();
$config['per_page'] = 10;
if (!isset($_GET[$config['query_string_segment']]) || $_GET[$config['query_string_segment']] < 1) {
$_GET[$config['query_string_segment']] = 1;
}
$limit = $config['per_page'];
$offset = ($this->input->get($config['query_string_segment']) - 1) * $limit;
$this->pagination->initialize($config);
$data = $this->get_data();
$data['posts'] = $this->Posts_model->get_posts($limit, $offset);
$data['offset'] = $offset;
$this->load->view('partials/header', $data);
$this->load->view('dashboard/posts');
$this->load->view('partials/footer');
}
鉴于分页项是由 $data['pagination'] = $this->pagination->create_links();
生成的 "behind the scenes",我无法实现分页链接的必要配置。
我怎样才能做到这一点?
在您的 _initPagination
中,您有以下代码行
$config['base_url'] = base_url($path);
你可以把上面的改成
$config['base_url'] = "http://".$_SERVER['HTTP_HOST'] . $path;