我正在使用此站点的ajax分页方法并做了一些小的更改:https://www.codexworld.com/codeigniter-ajax-pagination-with-search-filter/ 这似乎工作正常,直到我在搜索后尝试使用分页。
例如。当我搜索某些内容时,分页链接会正确显示,但是当我单击下一页时,它会重置为默认分页。我错过了什么吗?我已经查找和比较了一整天,似乎找不到问题所在。我希望有人可以帮我看一下这个,看看我是否遗漏了一些东西。
这是ajax分页库
<?php if (!defined('BASEPATH')) exit('No direct script access allowed');
class Ajax_pagination{
var $base_url = '';
var $total_rows = '';
var $per_page = 10;
var $num_links = 2;
var $cur_page = 0;
var $first_link = 'First';
var $next_link = '»';
var $prev_link = '«';
var $last_link = 'Last';
var $uri_segment = 3;
var $full_tag_open = '<ul class="pagination">';
var $full_tag_close = '</ul>';
var $first_tag_open = '<li>';
var $first_tag_close = '</li>';
var $last_tag_open = '<li>';
var $last_tag_close = '<li>';
var $cur_tag_open = '<li class="active"><a href="#">';
var $cur_tag_close = '</a></li>';
var $next_tag_open = '<li>';
var $next_tag_close = '</li>';
var $prev_tag_open = '<li>';
var $prev_tag_close = '</li>';
var $num_tag_open = '<li>';
var $num_tag_close = '</li>';
var $target = '';
var $anchor_class = '';
var $show_count = false;
var $link_func = 'getData';
var $loading = '.loading';
/**
* Constructor
* @access public
* @param array initialization parameters
*/
function CI_Pagination($params = array()){
if (count($params) > 0){
$this->initialize($params);
}
log_message('debug', "Pagination Class Initialized");
}
/**
* Initialize Preferences
* @access public
* @param array initialization parameters
* @return void
*/
function initialize($params = array()){
if (count($params) > 0){
foreach ($params as $key => $val){
if (isset($this->$key)){
$this->$key = $val;
}
}
}
// Apply class tag using anchor_class variable, if set.
if ($this->anchor_class != ''){
$this->anchor_class = 'class="' . $this->anchor_class . '" ';
}
}
function getCurrPage(){
return $this->cur_page;
}
/**
* Generate the pagination links
* @access public
* @return string
*/
function create_links(){
// If our item count or per-page total is zero there is no need to continue.
if ($this->total_rows == 0 OR $this->per_page == 0){
return '';
}
// Calculate the total number of pages
$num_pages = ceil($this->total_rows / $this->per_page);
// Is there only one page? Hm... nothing more to do here then.
if ($num_pages == 1){
// $info = 'Showing : ' . $this->total_rows;
$info = '';
return $info;
}
// Determine the current page number.
$CI =& get_instance();
if ($CI->uri->segment($this->uri_segment) != 0){
$this->cur_page = $CI->uri->segment($this->uri_segment);
// Prep the current page - no funny business!
$this->cur_page = (int) $this->cur_page;
}
$this->num_links = (int)$this->num_links;
if ($this->num_links < 1){
show_error('Your number of links must be a positive number.');
}
if ( ! is_numeric($this->cur_page)){
$this->cur_page = 0;
}
// Is the page number beyond the result range?
// If so we show the last page
if ($this->cur_page > $this->total_rows){
$this->cur_page = ($num_pages - 1) * $this->per_page;
}
$uri_page_number = $this->cur_page;
$this->cur_page = floor(($this->cur_page/$this->per_page) + 1);
// Calculate the start and end numbers. These determine
// which number to start and end the digit links with
$start = (($this->cur_page - $this->num_links) > 0) ? $this->cur_page - ($this->num_links - 1) : 1;
$end = (($this->cur_page + $this->num_links) < $num_pages) ? $this->cur_page + $this->num_links : $num_pages;
// Add a trailing slash to the base URL if needed
$this->base_url = rtrim($this->base_url, '/') .'/';
// And here we go...
$output = '';
// SHOWING LINKS
if ($this->show_count){
$curr_offset = $CI->uri->segment($this->uri_segment);
$info = 'Showing ' . ( $curr_offset + 1 ) . ' to ' ;
if( ( $curr_offset + $this->per_page ) < ( $this->total_rows -1 ) )
$info .= $curr_offset + $this->per_page;
else
$info .= $this->total_rows;
$info .= ' of ' . $this->total_rows . ' | ';
$output .= $info;
}
// Render the "First" link
if ($this->cur_page > $this->num_links){
$output .= $this->first_tag_open
. $this->getAJAXlink( '' , $this->first_link)
. $this->first_tag_close;
}
// Render the "previous" link
if ($this->cur_page != 1){
$i = $uri_page_number - $this->per_page;
if ($i == 0) $i = '';
$output .= $this->prev_tag_open
. $this->getAJAXlink( $i, $this->prev_link )
. $this->prev_tag_close;
}
// Write the digit links
for ($loop = $start -1; $loop <= $end; $loop++){
$i = ($loop * $this->per_page) - $this->per_page;
if ($i >= 0){
if ($this->cur_page == $loop){
$output .= $this->cur_tag_open.$loop.$this->cur_tag_close; // Current page
}else{
$n = ($i == 0) ? '' : $i;
$output .= $this->num_tag_open
. $this->getAJAXlink( $n, $loop )
. $this->num_tag_close;
}
}
}
// Render the "next" link
if ($this->cur_page < $num_pages){
$output .= $this->next_tag_open
. $this->getAJAXlink( $this->cur_page * $this->per_page , $this->next_link )
. $this->next_tag_close;
}
// Render the "Last" link
if (($this->cur_page + $this->num_links) < $num_pages){
$i = (($num_pages * $this->per_page) - $this->per_page);
$output .= $this->last_tag_open . $this->getAJAXlink( $i, $this->last_link ) . $this->last_tag_close;
}
// Kill double slashes. Note: Sometimes we can end up with a double slash
// in the penultimate link so we'll kill all double slashes.
$output = preg_replace("#([^:])//+#", "\\1/", $output);
// Add the wrapper HTML if exists
$output = $this->full_tag_open.$output.$this->full_tag_close;
?>
<script>
function getData(page){
$.ajax({
method: "POST",
url: "<?php echo site_url('/Common/Check'); ?>",
success: function(data){
if(data==true){
console.log(page);
$.ajax({
method: "POST",
url: "<?php echo $this->base_url; ?>"+page,
data: { page: page },
beforeSend: function(){
$('<?php echo $this->loading; ?>').show();
},
success: function(data){
console.log("<?php echo $this->base_url; ?>"+page);
$('<?php echo $this->loading; ?>').hide();
$('<?php echo $this->target; ?>').html(data);
}
});
}else{
window.location.href="<?php echo site_url('/');?>";
}
}
});
}
</script>
<?php
return $output;
}
function getAJAXlink($count, $text) {
$pageCount = $count?$count:0;
return '<a href="javascript:void(0);"' . $this->anchor_class . ' data-per-
page="'.$this->per_page.'" onclick="'.$this->link_func.'('.$pageCount.')">'.
$text .'</a>';
}
}
Controller
public function index()
{
$conditions = array();
$data = array();
$totalRec = count($this->ActivitiesModel->admin_get_and_search($conditions));
$config['target'] = '#list';
$config['base_url'] = site_url('/AdminActivities/Search');
$config['total_rows'] = $totalRec;
$config['per_page'] = $this->get_per_page();
$this->ajax_pagination->initialize($config);
$data['links'] = $this->ajax_pagination->create_links();
$data['datatable'] = $this->ActivitiesModel->admin_get_and_search(array('limit'=>$this->get_per_page()));
$data['user'] = $this->AccountModel->get_person($this->get_person_id());
$this->load->view('layout/admins/common/header');
$this->load->view('layout/admins/common/navigation');
$this->load->view('layout/admins/common/title');
$this->load->view('layout/admins/common/errors');
$this->load->view('admins/activities/index',$data);
$this->load->view('layout/admins/common/footer');
}
public function search(){
$conditions = array();
$page = $this->input->post('page');
if(!$page){
$offset = 0;
}else{
$offset = $page;
}
$keywords = $this->input->post('keywords');
if(!empty($keywords)){
$conditions['search']['keywords'] = $keywords;
}
$totalRec = count($this->ActivitiesModel->admin_get_and_search($conditions));
$config['target'] = '#list';
$config['base_url'] = site_url('/AdminActivities/Search');
$config['total_rows'] = $totalRec;
$config['per_page'] = $this->get_per_page();
$this->ajax_pagination->initialize($config);
$conditions['start'] = $offset;
$conditions['limit'] = $this->get_per_page();
$data['links'] = $this->ajax_pagination->create_links();
$data['datatable'] = $this->ActivitiesModel->admin_get_and_search($conditions);
$this->load->view('admins/activities/ajax_pagination', $data, false);
}
查看
<script>
function searchFilter() {
// get current page number
var page_num = parseInt($('li.active a').text()) - 1;
// get active li parent element to get Data-Per-Page value
var active_parent = $('li.active a').parent('li');
console.log('page_num: ' + page_num);
var item_per_page = parseInt(active_parent.prev('li').find('a').data('per-page'));
// if NaN then use Next element
if (isNaN(item_per_page)) {
item_per_page = parseInt(active_parent.next('li').find('a').data('per-page'));
}
console.log('item_per_page: ' + item_per_page);
// Query string Keyword
var keywords = $('#search').val();
console.log('keywords: ' + keywords);
// Calculate the Offset
var page = (page_num * item_per_page);
console.log('page: ' + page);
// attach custom payload to ajax post
$.ajaxSetup({
data: {
'page': page_num,
keywords: keywords
},
});
$.ajax({
method: "POST",
url: "<?php echo site_url('/Common/Check'); ?>",
success: function(data){
if(data==true){
$.ajax({
type: 'POST',
url: '<?php echo site_url('/AdminDocuments/Search/'); ?>'+page_num,
data:'page='+page_num+'&keywords='+keywords,
beforeSend: function () {
$('.loading').show();
},
success: function (html) {
$('#list').html(html);
$('.loading').fadeOut("slow");
}
});
}else{
window.location.href="<?php echo site_url('AdminLogin');?>";
}
}
});
// Use same function to build filter output with pagination
getData(page);
}
</script>
<div id="maincontainer">
<div class="row col-sm-8">
<input type="text" name="search" id="search" class="form-control" placeholder="Search" onkeyup="searchFilter()">
</div>
<div id="list" class="row">
<div class="col-sm-12 table-responsive">
<table class="table">
<tbody>
<?php
if(!empty($datatable)){
foreach ($datatable as $data){
?>
<tr class="text-left">
<td><?php echo $data['action']; ?> onto the <?php echo $data['page']; ?> Page on <?php echo $data['created_on']; ?></td>
</tr>
<?php
}
}else{
?>
<tr>
<td colspan="7">You do not have any items at the moment</td>
</tr>
<?php
}
?>
</tbody>
</table>
</div>
<div class="pagination-links pull-right">
<?php echo $links; ?>
</div>
</div>
<div class="loading" style="display: none;">
<div class="content">
<img src="<?php echo base_url().'assets/images/loading/loading.gif'; ?>"/>
</div>
</div>
</div>
最佳答案
是的!,你失踪了...
You missing to pass 'page_num' in '
onkeyup="searchFilter()"
'
您正在使用类似函数 searchFilter(page_num) { } 的函数,但没有发送“page_num”值(value)。因此,当您使用 AJAX 进行 POST 时,它将始终为“0”并且您的分页将会重置。
另一种方法是使用在 Ajax_pagination
库类中编写的相同 getData(page)
函数。在此之前,请在类中更改一点代码:
更新 Ajax_pagination > getAJAXlink 方法:
function getAJAXlink($count, $text) {
$pageCount = $count?$count:0;
return '<a href="javascript:void(0);"' . $this->anchor_class . ' data-per-
page="'.$this->per_page.'" onclick="'.$this->link_func.'('.$pageCount.')">'.
$text .'</a>';
}
JavaScript:
<script type="text/javascript">
function searchFilter() {
// get current page number
var page_num = parseInt($('li.active a').text()) - 1;
// get active li parent element to get Data-Per-Page value
var active_parent = $('li.active a').parent('li');
// get per page count
var item_per_page = parseInt(active_parent.prev('li').find('a').data('per-page'));
// if NaN then use Next element
if (isNaN(item_per_page)) {
item_per_page = parseInt(active_parent.next('li').find('a').data('per-page'));
}
// Query string Keyword
var keywords = $('#search').val();
// Calculate the Offset
var page = (page_num * item_per_page);
// attach custom payload to ajax post
$.ajaxSetup({
data: {
'page': page_num,
keywords: keywords
},
});
// No Need to your Ajax Code Here, The getData already gives you filtered data
// and will set in #list, basically getData posting Common/Check url and getting data
// Here is getData post request analysis report.... :)
// Use same function to build filter output with pagination
getData(page);
}
</script>
了解 Ajax_pagination 类中 getData Ajax 请求的流程
<script type="text/javascript">
function getData(page) {
// ajax start
$.ajax({
method: "POST",
// sending request to Common/Check Controller/method
url: "<?php echo site_url('/Common/Check'); ?>",
success: function(data) {
// if response returns
if (data) {
console.log(page);
// call another ajax request
$.ajax({
method: "POST",
// sending request to Class Ajax_pagination Config base_url link
url: "<?php echo $this->base_url; ?>" + page,
// sending payloads page e.g. 10, 20, 30...
data: {
page: page
},
beforeSend: function() {
$('<?php echo $this->loading; ?>').show();
},
success: function(data) {
// if response returns
console.log("<?php echo $this->base_url; ?>" + page);
$('<?php echo $this->loading; ?>').hide();
// set response inside Ajax_pagination Config target element e.g #list
$('<?php echo $this->target; ?>').html(data);
}
});
} else {
window.location.href = "<?php echo site_url('/');?>";
}
}
});
}
</script>
一个好方法是使用 CodeIgniter 内置分页类。这非常简单,您只需通过 Google 搜索即可找到大量示例代码。
然后您可以组合您的 Controller 、模型和 View 来创建 Ajax 响应,毕竟返回一个包含数据的表格 html 行就可以了 或 返回一些 div 奇特的内容。背后的逻辑是,您可以通过在 Controller 内使用CodeIgniter Pagination Class来调用简单的ajax来构建您的内容,并且可以通过传递限制和偏移量来通过模型获取数据,就是这样!
来源和文档:CodeIgniter Pagination Class
@JianYA,请经常检查浏览器网络面板,看看我们在使用 Ajax 时得到了什么响应。它可能会消除更多疑问,而不是假设。您正在 getData 函数
中使用“Common/Check”,所以这里有一些问题要问您:
- 你们有通用的 Controller 和检查方法吗?
- 您是否设置了
$route['Common/Check'] = 'YourController/YourMethod';
如果您没有此 Controller ,则在config 文件夹
内的routes.php
?
关于php - Codeigniter ajax 分页搜索结果不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44734796/