纯javascript longpolling聊天

时间:2013-10-27 10:28:19

标签: javascript php ajax chat long-polling

所以我已经开始了一个项目,在那里我想进行在线ajax聊天,但我不想使用jQuery JSON,COMET等。我正在寻找纯粹的javascript,没有库没有框架。

好消息是我已经进行了聊天并且工作正常。我为什么要发这个帖子?因为我根本找不到任何用于长轮询的纯JavaScript解决方案。目前我正在使用setInterval方法“请求”数据库发送数据库中的任何内容。现在,每当我得到回复时,如何执行我的ajax请求? (长轮询)。

请记住,我不是在寻找jQuery解决方案或者你有什么......我使用的是纯JavaScript和PHP。没有框架或库。

提前致谢。

1 个答案:

答案 0 :(得分:0)

我相信这与您的寻找相对接近 - 在nettuts上引用一个vanilla js ajax教程:

load('test.txt', function(xhr) { 
    document.getElementById('container').innerHTML = xhr.responseText;  
    // you would obviously custom tailor this peice to utilize your specific data
});  

function load(url, callback) {  
    var xhr;  

    if(typeof XMLHttpRequest !== 'undefined') xhr = new XMLHttpRequest();  
    else {  
        var versions = ["MSXML2.XmlHttp.5.0",   
                        "MSXML2.XmlHttp.4.0",  
                        "MSXML2.XmlHttp.3.0",   
                        "MSXML2.XmlHttp.2.0",  
                        "Microsoft.XmlHttp"]  

         for(var i = 0, len = versions.length; i < len; i++) {  
            try {  
                xhr = new ActiveXObject(versions[i]);  
                break;  
            }  
            catch(e){}  
         } // end for  
    }  

    xhr.onreadystatechange = ensureReadiness;  

    function ensureReadiness() {  
        if(xhr.readyState < 4) {  
            return;  
        }  

        if(xhr.status !== 200) {  
            return;  
        }  

        // all is well    
        if(xhr.readyState === 4) {  
            callback(xhr);  
        }             
    }  

    xhr.open('GET', url, true);  
    xhr.send('');  
}

您可以根据返回值

将“成功”处理程序构建到“确保就绪”中

heres a link to the nettuts tutorial

and another to the MDN ajax API docs