如何使用 jQuery DataTables 插件实现服务器端处理?
Posted
技术标签:
【中文标题】如何使用 jQuery DataTables 插件实现服务器端处理?【英文标题】:How to implement server-side processing with jQuery DataTables plugin? 【发布时间】:2012-07-11 02:02:42 【问题描述】:我正在使用 jQuery DataTables 插件来显示由多个表组合而成的一组结果。我正在尝试通过插件实现server-side processing 以改善页面加载时间。我不太清楚如何将example DataTables 提供给我的场景。有什么想法/建议吗?
$('#results').dataTable(
"sAjaxSource": "../server_processing.php",
"bProcessing": true,
"bServerSide": true,
"bDeferRender": false,
)
原PHP函数:
function build_data_list()
global $org_id;
global $dbh;
global $req_ids;
global $user_list;
$sth = $dbh->query ("SELECT
l4.name as L4name,
l3.name as L3name,
l2.name as L2name,
l1.name as L1name,
u.id,
u.last_name,
u.first_name,
FROM user_grp_indx ugi, groups l4, groups l3, groups l2, groups l1, users p
WHERE
ugi.user_id = u.id
AND l4.id = ugi.grp_id
AND l4.parent = l3.id
AND l3.parent = l2.id
AND l2.parent = l1.id
ORDER BY u.id", PDO::FETCH_ASSOC);
$row = $sth->fetch();
$item['user_id'] = $row['id'];
$item['user_info'] = '<a href="../users/index.php?pq=';
$item['user_info'] .= $row['id'].'">';
$item['user_info'] .= $row['last_name']. ", " . $row['first_name'] . "</a>";
$item['l1_name'] = $row['L1name'];
$item['l2_name'] = $row['L2name'];
$item['l3_name'] = $row['L3name'];
$item['l4_name'] = $row['L4name'];
for ($i=0; $i < sizeof($req_ids) ; $i++ )
$item['req'.$i] = (chk_req_status($item['user_id'],$req_ids[$i]) ? "<span title=\"Yes\"></span><img src=\"../../media/icons/tick.png\" alt=\"Yes\" />" :
"<span title=\"No\"></span><img src=\"../../media/icons/cross.png\" alt=\"No\" />");
$old_L1id = $row['L1id'];
$old_user_id = $row['id'];
while ($row = $sth->fetch())
$L1id = $row['L1id'];
$user_id = $row['id'];
if ($L1id == $old_L1id && $user_id == $old_user_id )
$item['l2_name'] .= "<br/>" . $row['L2name'];
$item['l3_name'] .= "<br/>" . $row['L3name'];
$item['l4_name'] .= "<br/>" . $row['L4name'];
continue;
$user_list[] = $item;
$old_L1id = $L1id;
$old_user_id = $user_id;
$item['user_id'] = $row['id'];
$item['user_info'] = '<a href="../users/index.php?pq=';
$item['user_info'] .= $row['id'].'">';
$item['user_info'] .= $row['last_name']. ", " . $row['first_name'] . "</a>";
//add inital level stuff to the new record.
$item['l1_name'] = $row['L1name'];
$item['l2_name'] = $row['L2name'];
$item['l3_name'] = $row['L3name'];
$item['l4_name'] = $row['L4name'];
for ($i=0; $i < sizeof($req_ids) ; $i++ )
$item['req'.$i] = (chk_req_status($item['user_id'],$req_ids[$i]) ? "<span title=\"Yes\"></span><img src=\"../../media/icons/tick.png\" alt=\"Yes\" />" :
"<span title=\"No\"></span><img src=\"../../media/icons/cross.png\" alt=\"No\" />");
原始 html/PHP:
<tbody>
<?php foreach($user_list as $item)
print "<tr>";
print "<td class=\"hidden\">$item['user_id']</td>";
print "<td>$item['user_info']</td>";
print "<td>$item['l1_name']</td>";
print "<td>$item['l2_name']</td>";
print "<td>$item['l3_name']</td>";
print "<td>$item['l4_name']</td>";
for ($i=0; $i < sizeof($req_ids) ; $i++ )
print '<td>'.( chk_req_status($item['user_id'],$req_ids[$i]) ? "<span title=\"Yes\"></span><img src=\"../../media/icons/tick.png\" alt=\"Yes\" />":
"<span title=\"No\"></span><img src=\"../../media/icons/cross.png\" alt=\"No\" />").'</td>';
print "</tr>";
?>
</tbody>
【问题讨论】:
您的 PHP 发出的是 HTML 还是 JSON?它不应该是在初始 HTML 之后发出的 JSON,因为当用户更改表格的显示页面时,DataTables 会要求提供 JSON? 【参考方案1】:这有什么帮助吗?
Server-side processing | PHP with mysql
服务器端处理 | PHP 与 MySQL 该脚本作为 DataTables 测试和开发的基础,因此它始终是最新的,并且将始终通过服务器端处理实现 DataTables 中支持的所有功能(正则表达式过滤除外) - 出于数据库访问速度的原因)。
要在您自己的服务器上使用代码,只需更改 $aColumns 数组以列出您希望从数据库中包含的列,将 $sIndexColumn 设置为索引列(为了速度),将 $sTable 设置为表名,最后将你的数据库连接参数填入$gaSql。请注意,此脚本使用需要 PHP 5.2 或更高版本的 json_encode。有关与旧版本兼容的此脚本版本,请参阅 PHP 4 兼容版本。
【讨论】:
以上是关于如何使用 jQuery DataTables 插件实现服务器端处理?的主要内容,如果未能解决你的问题,请参考以下文章
如何使用 jQuery DataTables 插件实现服务器端处理?
如何使用 jQuery DataTables 插件过滤带有特殊字符的结果?
如何从 Datatables jQuery 插件中提取过滤后的数据?
如何使用 jQuery DataTables 插件在特定列中搜索?