我在使用Ajax和PHP初始化DataTable时遇到了一些麻烦。据检查员说,错误是:
Uncaught TypeError: Cannot read property 'length' of undefined jquery.dataTables.js:2649
(anonymous function) jquery.dataTables.js:2649
oSettings.jqXHR.$.ajax.success jquery.dataTables.js:8749
c jquery.js:3048
p.fireWith jquery.js:3160
k jquery.js:8235
r jquery.js:8778
我按照数据表网站上的说明操作,但显然我做错了。这不是php部分,我刚刚检查过它并且它返回了一个json文件。
这就是我所拥有的。
提前致谢。
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Chromo Insiders</title>
<script src="//ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js"></script>
<script src="DataTables/media/js/jquery.dataTables.js"></script>
<script type="application/javascript" language="javascript" src="insiders.js"></script>
<link rel="stylesheet" type="text/css" href="ci_style.css" />
<style type="text/css">
@import 'DataTables/media/css/demo_table_jui.css';
</style>
</head>
<body>
<header>
<h1>Chromo Insiders</h1>
</header>
<table id="datatables">
<thead>
<tr>
<th>email</th>
<th>Last Name</th>
<th>First Name</th>
<th>Date Registered</th>
</tr>
</thead>
<tbody>
</tbody>
</table>
</body>
</html>
这是脚本:
$(document).ready(function(e) {
$('#datatables').dataTable( {
"bProcessing": true,
"sAjaxSource": 'process.php'
} );
});
以防您需要查看php代码:
<?php
try {
$conn = require_once 'dbConnect.php';
$sql = "SELECT email, lastName, firstName, state, dateRegistered FROM Users";
$result = $conn->prepare($sql) or die ($sql);
if(!$result->execute()) return false;
if($result->rowCount() > 0) {
$json = array();
while($row = $result->fetch()){
$json[] = array(
'email' => $row['email'],
'lastName' => $row['lastName'],
'firstName' => $row['firstName'],
'dateRegistered' => $row['dateRegistered'],
'state' => $row['state']
);
}
$json['success'] = true;
echo json_encode($json);
}
} catch(PDOException $e) {
echo 'Error: ' . $e->getMessage();
}
?>
答案 0 :(得分:1)
您需要更改您的回复:
if($result->rowCount() > 0) {
$json = array();
while($row = $result->fetch()){
/** MAKE ARRAY NON ASSOCIATIVE **/
$json[] = array(
$row['email'],
$row['lastName'],
$row['firstName'],
$row['dateRegistered'],
$row['state']
);
}
/*** MAKE RESPONSE HAVE 'aaData' ENTRY ****/
$response = array();
$response['success'] = true;
$response['aaData'] = $json;
echo json_encode($response);
此处参考:http://datatables.net/release-datatables/examples/data_sources/ajax.html。具体做法是:
DataTables期望一个带有一个名为“aaData”的数组的对象 数据来源。
此外,您的表格没有“州”列,但您的ajax响应确实...