我使用jquery和AJAX制作了一个简单的聊天脚本,但其中的一大漏洞是我只能正确地与自己聊天:P
继承了我主文件的javascript
<script src="http://jqueryjs.googlecode.com/files/jquery-1.2.6.min.js" type="text/javascript"></script>
<script type="text/javascript">
$(document).ready(function(){
$("#status").load('ajaxLoad.php');
$("#userArea").submit(function(){
var hr = new XMLHttpRequest();
var id = '<?php echo $id; ?>';
var name = '<?php echo $name; ?>';
var url = "ajaxPost.php";
var msg = document.getElementById("messages").value;
var vars = "messages="+msg+"&id="+id+"&name="+name;
hr.open("POST", url, true);
hr.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
hr.onreadystatechange = function() {
if(hr.readyState == 4 && hr.status == 200) {
var return_data = hr.responseText;
$("#status").append(return_data);
}
}
hr.send(vars);
return false;});
});
并且继承我的第二个文件“ajaxLoad.php”
<?php
include_once "connect_to_mysql.php";
$sql = mysql_query("SELECT messages,id FROM chat");
while($row = mysql_fetch_array($sql))
{
echo $row["messages"];
}
?>
现在我需要的是不断刷新“ajaxLoad.php”,以便用户可以实时聊天而无需刷新页面......有什么方法吗?
答案 0 :(得分:5)
// reload every second
setInterval(function() {
$("#status").load('ajaxLoad.php');
}, 1000);
小心向服务器发出过多请求。这将是相当密集的。
答案 1 :(得分:2)
您可以使用javascript setInterval
每隔x秒调用一次php脚本。
答案 2 :(得分:2)
如果你想获得优势,你应该研究WebSockets。