我一直在尝试使用 ajax 从数据库中检索新行。就像在 facebook 聊天中发生的事情一样。我一直在做的是每两秒使用 ajax 从数据库中获取最后十行,并尝试显示用户没有看到的行。我有两列,id 和 name。我创建了一个有序列表并将每个 li 元素 id 设置为数据库中的 id。每个 li 代表一行。然后我尝试获取最后一个 li 元素的 id 并检查数据库中的 id 是否更大,如果是则附加一个包含 id 和名称的新 li。但由于某种原因,它只是每两秒附加整个 10 行。我做错了什么?这是我正在使用的代码。
<ol id="output"><li id="1">test</li></ol>
<script id="source" language="javascript" type="text/javascript">
function reloadw()
{
$.ajax({
url: 'api.php',
data: "",
dataType: 'json',
success: function(rows)
{
for (var i in rows)
{
var row = rows[i];
var lastId = $('ol#output li').attr('id');
var id = row[0];
var vname = row[1];
if(id > lastId){
$('#output').append("<li id="+id+"><b>id: </b>"+id+"<b> name: </b>"+vname+"</li>");
}}
}
});
} setInterval(reloadw,2000);
这是我在从数据库中检索数据时使用的
$result = mysql_query("SELECT * FROM $tableName ORDER BY id");
$data = array();
for($i=0;$i<=9;$i++){
$row = mysql_fetch_row($result);
$data[] = $row;
}
echo json_encode( $data );