不断刷新ajax

时间:2012-03-08 20:52:49

标签: php jquery ajax

我使用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”,以便用户可以实时聊天而无需刷新页面......有什么方法吗?

3 个答案:

答案 0 :(得分:5)

// reload every second
setInterval(function() {
  $("#status").load('ajaxLoad.php');
}, 1000);

小心向服务器发出过多请求。这将是相当密集的。

答案 1 :(得分:2)

您可以使用javascript setInterval每隔x秒调用一次php脚本。

https://developer.mozilla.org/en/window.setInterval

答案 2 :(得分:2)

如果你想获得优势,你应该研究WebSockets