0
我創建了這個聊天系統,用於正常工作,直到消息數量增加(超過300條消息,我希望達到1000條)開始導致慢速腳本並花費時間檢索所有數據。 這個想法取決於選擇數據的XML風格,然後將其添加到特定的選項卡,並重復與setTimeout的行爲,有沒有其他方式我可以做我真的需要的想法,這裏是我的代碼。使用jquery獲取大量數據
function updateMessage()
{
$.post("db.php",
{MsgNo :$("#no_of_msgs").val()},
function(data)
{
$(data).find("message").each(function() {
var msg_id = $(this).find("msg_id").text();
var date_time = $(this).find("date_time").text();
var from_user = $(this).find("from_user").text();
var from_user_id = $(this).find("from_user_id").text();
var from_group = $(this).find("from_group").text();
var to_user = $(this).find("to_user").text();
var to_user_id = $(this).find("to_user_id").text();
var to_group = $(this).find("to_group").text();
var msg_type = $(this).find("msg_type").text();
var msg = $(this).find("msg").text();
var from_grp_abr = $(this).find("from_grp_abr").text();
var to_grp_abr = $(this).find("to_grp_abr").text();
var flagged = $(this).find("flagged").text();
var onlydate = getonlydate(date_time);
$("#no_of_msgs").val(msg_id);
if (from_group == $("#login").val())
{
var reply = '';
}
else {var reply = 'reply';}
if(from_user == "")
{
var handle_reply = from_grp_abr;
}
else
{
var handle_reply = from_user;
}
var html = "<tr id='row_"+msg_id+"'>";
html += "<td><a class='bullet' onclick='changeStatus(\""+msg_id+"\")'> <\/a><\/td>";
html += "<td><a class='"+reply+"' onclick=\"reply('"+escape(handle_reply)+"','"+escape(to_user)+"',"+from_user_id+","+to_user_id+");\"> <\/a><\/td>";
html += "<td class='time'>"+date_time+"<\/td>";
html += "<td>"+from_user+" ["+from_grp_abr+"]"+"<\/td>";
html += "<td>"+to_user+" ["+to_grp_abr+"]"+"<\/td>";
html += "<td><a href='#' class="+msg_type+"><\/a><\/td>";
html += "<td><a id='flag_"+msg_id+"' class='"+class_flag+"' onclick='flagMsg("+msg_id+")'> <\/a><\/td>";
html += "<td>"+msg+"<\/td>";
html += "<td>"+from_grp_abr+"<\/td><\/tr>";
$('#no_of_msgs').val(msg_id);
$("#tbody1").prepend(html);
updatetabledata('t1');
alternateRows('t1');
//append data to tab2 messages received
if (to_group == $("#login").val())
{
$("#tbody2").prepend(html);
updatetabledata('t2');
alternateRows('t2');
}
//append data to tab3 sent messages
else if (from_group == $("#login").val())
{
$("#tbody3").prepend(html);
updatetabledata('t3');
alternateRows('t3');
}
if(from_group != $("#login").val())
{
$("#tbody"+from_group).prepend(html);
updatetabledata('t'+from_group);
alternateRows('t'+from_group);
}
if(to_group != $("#login").val())
{
$("#tbody"+to_group).prepend(html);
updatetabledata('t'+to_group);
alternateRows('t'+to_group);
}
});
});
setTimeout('updateMessage()',3000);
}
我在想,問題在於使用each(),然後在同一時間在多個選項卡上分發數據的任何想法。
我已經這樣做了。是的,這些消息似乎是分批檢索的,但第一次檢查它們是否正確?如果是的話,我會如何將它們分成不同的標籤。 – Sarah 2010-04-13 08:43:09
您每個週期收到多少條消息;鑑於你每三秒鐘檢查一次,它不會超過一對?嘗試不同瀏覽器中的腳本...他們變化堆。此外,大多數現代瀏覽器都帶有一個javascript profiler(我只使用了firebug中的一個),他們都應該很擅長告訴你哪些方法正在耗盡你的時間。將您的功能分解爲幾種方法將有助於找出問題。 – CurtainDog 2010-04-15 05:40:38