我有一个使用DataTables的用户表,它将包含超过200行。当我使用DataTables作为默认值"pageLength": 10
时,它看起来很好,这就是表格示例。
Username | Type | Request |
user01 1 request01
user02 1 request02
user03 2 request03
user04 1 request04
user05 1 request05
user06 1 request06
user07 1 request07
user08 1 request08
user09 1 request09
user10 1 request10
Showing 1 to 10 of 200 entries
首先 上一页 1 2 3 ... 20 下一步 最后
因此,为了缩短加载时间,我决定使用"processing": true
和"serverSide": true
。然后我遇到了这个"serverSide" : true
的问题,它在表格中打印了200行数据。
Showing 0 to 0 of 0 entries (filtered from NaN total entries)
。然后分页仍然打印,在我点击页面 2 之后,它什么也没做。
我想DataTables获得第一个10个数据,点击 2 之后,它会再获得10个,依此类推。
我正在使用CodeIgniter,这是我的代码:
在我的观点+ Js :
上<select name="task" id="task">
<option value="1">Task 1</option>
<option value="2">Task 2</option>
</select>
<table id="user-request" class="table">
<thead>
<tr>
<th>Username</th>
<th>Type</th>
<th>Request</th>
</tr>
</thead>
</table>
<script>
... on task change ...
... var task = $("#task").val(); ...
$('#user-request').DataTable({
'processing': true,
'serverSide': true,
'ajax': {
'type': 'POST',
'url': base_url+'user/get_user_request',
'data': {"task":task,"csrf_token":$("input[name=csrf_token]").val()}
}
})
</script>
注意:任务是一个不同的组,例如Class 1或Class 2,Orchard University或Harvard University
在我的控制器:
上$task = $this->input->post('task', TRUE);
$user_request = $this->model->all_user_request(task);
foreach ($user_request as $ur)
{
$arr = array();
$arr[] = $ur->username;
$arr[] = $ur->type;
$arr[] = $ur->request;
$data[] = $arr;
}
$output = array(
"data" => $data
);
if (COUNT($output) > 0)
{
echo json_encode($output);
}
在我的模型:
上public function all_user_request($task_id) {
$query = "SELECT * FROM user_request WHERE task_id = ?";
return $this->db->query($query, $task_id)->result();
}
注意:在模型中实际上使用的是2 INNER JOIN
,我只是简化了选择,只是在这里询问。 (仅在这里变成非规范化表。)
我试图仅使用数字数据在我的控制器中将draw
,recordsTotal
,recordsFiltered
添加到$output
。实施例
$output = array(
"draw" => 5,
"recordsTotal" => 5,
"recordsFiltered" => 5,
"data" => $data
);
if (COUNT($output) > 0)
{
echo json_encode($output);
}
我正在寻找答案但是,我认为问题出在这里,但我仍然不知道我必须在哪里获得draw
- recordsTotal
- recordsFiltered
数据。我看到其他人的另一个答案,他们使用"draw" => $_POST['draw']
,然后我尝试了,它什么也没做。
所以我正在尝试使用数字数据,但结果仍然相同。我需要一些帮助。它仍在表中打印200行数据。
Showing 0 to 0 of 0 entries (filtered from NaN total entries)
。然后分页仍然打印,在我点击页面 2 之后,它什么也没做。
答案 0 :(得分:2)
数据表发送您需要的所有内容 - 如果您在网络下查看控制台,您会看到,他们使用ajax-get方法将这些请求发送到服务器
GET
参数如下
draw
columns
start
length
search
您可以找到整个列表here
这意味着 - 你必须正确调整你的模型......
类似的东西应该起作用
public function all_user_request($task_id)
{
$intStart = intval($this->input->get("start"));
$intLength = intval($this->input->get("length"));
$strSearch = (strlen($this->input->get("search")["value"]) >= 2) ? $this->input->get("search",true)["value"] : false;
$order = $this->input->get("order",true);
$this->setQuery($task_id,$strSearch);
$query = $this->db->get();
$this->recordsTotal = $query->num_rows();
$this->setQuery($task_id, $strSearch);
if ($intStart >= 0 && $intLength > 0)
{
$this->db->limit($intLength,$intStart);
}
$strOrderField = 'username';
$strDirection = "ASC";
if (is_array($order))
{
switch($order[0]['column'])
{
case 1:
$strOrderField = 'type';
break;
case 2:
$strOrderField = 'request';
break;
}
if (!empty($order[0]['dir'])) $strDirection = $order[0]['dir'];
}
$this->db->order_by($strOrderField,$strDirection);
$query = $this->db->get();
$arrData = $query->result();
return $arrData;
}
public function getRecordsTotal()
{
return $this->recordsTotal;
}
private function setQuery($task_id, $strSearch="")
{
$this->db
->select('*')
->from('user_request')
->where('task_id', $task_id);
if (!empty($strSearch))
{
$this->db->like('task_id', $strSearch);
}
}
和您的控制器
//controller
$task = $this->input->post('task', TRUE);
$user_request = $this->model->all_user_request($task);
$data = [];
foreach ($user_request as $ur)
{
$data[] = [
$ur->username,
$ur->type,
$ur->request
];
}
$arrCompiledData = [
'data' => $data,
'draw' => $this->input->get('draw'),
'recordsTotal' => $this->model->getRecordsTotal(),
'recordsFiltered' => $this->model->getRecordsTotal(),
];
$this->output
->set_content_type('application/json')
->set_output(json_encode($arrCompiledData));
请记住我刚写下来 - 也许有一些拼写错误,但您应该能够理解数据表请求的服务器端处理应该如何工作。
答案 1 :(得分:0)
只要您选择服务器模式,就必须通过请求管理所有内容。 因此,您必须动态创建输出数组的值:
<div class="container">
<div class="card card-container">
<p id="profile-name" class="profile-name-card"></p>
<form class="form-signin" method="POST">
<input type="text" name="search" id="search" class="form-control" placeholder="Search">
</form><!-- /form -->
<button class="btn btn-lg btn-primary btn-block btn-signin" value= "search" type="required" id="submit" name="submit">Search</button>
</div><!-- /card-container -->
<div class="row">
<div class="col-md-4">
<div id="search"></div>
<div class="caption">
<p></p>
</div>
</div>
和模型函数
$output = array(
"draw" => $_POST['draw'],
"recordsTotal" => $this->my_model->get_total_records(),
"recordsFiltered" => $this->my_model->get_total_filtered(),
"data" => $this->my_model->all_user_request($id)
);
答案 2 :(得分:0)
如果您使用serverSide = true
,则应提供自己的过滤计数和总计数。还提供您自己的搜索功能,订购等。使用控制器和放大器。以下型号供您参考。
<强>控制器强>
$task = $this->input->post('task', TRUE);
$user_request = $this->model->all_user_request($task);
$output = array(
'draw' => $this->input->post('draw', TRUE),
'recordsTotal' => $user_request['recordsTotal'],
'recordsFiltered => $user_request['recordsFiltered'],
'data' => empty($user_request['data'])? array() : $user_request['data']
);
echo json_encode($output);
<强>模型强>
public function all_user_request($task_id) {
$params = $this->input->post(null, TRUE);
$search_fields = array('username','type','request'); //change this into your table fields
$data = array();
$this->db->start_cache();
$this->db->select("username, type, request");
$this->db->from("user_request");
$this->db->where("task_id", $task_id);
if(!empty($params['search']['value'])){
$str = $params['search']['value'];
$this->db->group_start();
foreach($search_fields as $row){
$this->db->or_like($row, $str, 'BOTH');
}
$this->db->group_end();
}
$data['recordsTotal'] = $this->db->count_all_results();
$this->db->stop_cache();
$this->db->limit($params['length'], $params['start']);
$data['recordsFiltered'] = $this->db->count_all_results();
$query = $this->db->get();
$this->db->flush_cache();
foreach($query->result_array() as $row){
$data['data'][] = array_values($row);
}
return $data;
}