8

我在一个音乐网站上工作:我在服务器上有一个文本文件,其中包含当前播放歌曲的名称。我想每十五秒阅读一次文本文件,并更改我网站上显示的文本,而无需刷新。

现在,使用一点 jQuery 和 javascript,我实际上已经达到了第一次读取和显示文件的地步,但它不会刷新。我尝试了各种 setInterval 函数,但在我的一生中,我无法让这部分工作。任何帮助将不胜感激。

这是我所拥有的:

<script type="text/javascript"> 
$(document).ready(function() {
    jQuery.get('http://www.XXXXX.com/nowplaying/NowPlaying.txt', function(data) {
        var myvar = data;
        var parts = myvar.split(/\n/);
        var songtitle = parts[0];
        var songartist = parts[1];
        var songalbum = parts[2];
        var songtime = parts[3];
        $('#songtitleholder').html(songtitle);
        $('#songartistholder').html(songartist);
        $('#songalbumholder').html(songalbum);
    });
});​
</script>
4

6 回答 6

6

您可以将要执行的代码repeatedly放在函数中,并将该函数传递给setTimeout. setTimeout 的第二个参数将在millisecond.

在此处使用 setTimeout IMO 更多appropriate,因为它将排除发送请求和接收响应所花费的时间。它会send request every 5 second after receiving response.

<script type="text/javascript"> 

 $(document).ready(function() {

    function functionToLoadFile(){
      jQuery.get('http://www.XXXXX.com/nowplaying/NowPlaying.txt', function(data) {
       var myvar = data;
       var parts = myvar.split(/\n/);
       var songtitle = parts[0];
       var songartist = parts[1];
       var songalbum = parts[2];
       var songtime = parts[3];

       $('#songtitleholder').html(songtitle);
       $('#songartistholder').html(songartist);
       $('#songalbumholder').html(songalbum);
       setTimeout(functionToLoadFile, 5000);
    });
    }

    setTimeout(functionToLoadFile, 10);
});

</script>
于 2012-12-22T16:03:53.363 回答
3

您应该能够将示例包装在 setInterval 调用中,如下所示:

$(document).ready(function() {
    setInterval( function(){
    jQuery.get('http://www.XXXXX.com/nowplaying/NowPlaying.txt', function(data) {
        var myvar = data;
        var parts = myvar.split(/\n/);
        var songtitle = parts[0];
        var songartist = parts[1];
        var songalbum = parts[2];
        var songtime = parts[3];
        $('#songtitleholder').html(songtitle);
        $('#songartistholder').html(songartist);
        $('#songalbumholder').html(songalbum);
    });
    }, 15000);
});​
于 2012-12-22T16:03:46.140 回答
3

创建一个函数并调用它setInterval您可能希望在 URL 中添加一个时间戳,以便结果不会缓存

$(document).ready(function() {
    function refresh(){
        jQuery.get('http://www.XXXXX.com/nowplaying/NowPlaying.txt', { "t": $.now() }, function(data) {
            var myvar = data,
                parts = myvar.split(/\n/),
                songtitle = parts[0],
                songartist = parts[1],
                songalbum = parts[2],
                songtime = parts[3];

            $('#songtitleholder').html(songtitle);
            $('#songartistholder').html(songartist);
            $('#songalbumholder').html(songalbum);
        });
    }
    setInterval(refresh, 15000);
});​
于 2012-12-22T16:04:04.843 回答
1

解决方案使用setTimeout. setInterval当窗口在切换浏览器选项卡时失去焦点时,往往会排队。

$(document).ready(function() {
    getData();
});​

function getData() {
    setTimeout(function() {
        jQuery.get('http://www.XXXXX.com/nowplaying/NowPlaying.txt', function(data) {
            var myvar = data;
            var parts = myvar.split(/\n/);
            var songtitle = parts[0];
            var songartist = parts[1];
            var songalbum = parts[2];
            var songtime = parts[3];
            $('#songtitleholder').html(songtitle);
            $('#songartistholder').html(songartist);
            $('#songalbumholder').html(songalbum);

            /* repeat getData*/
            getData();
        });
    }, 15000)

}
于 2012-12-22T16:07:44.003 回答
0

为什么不试试这个?

    window.setInterval(function(){

    /// call your function here

    }, 15000);
于 2012-12-22T16:04:13.397 回答
0

除了setInterval按照其他人的答案使用之外,请确保文件没有通过请求被缓存:

jQuery.get("http://......./NowPlaying.txt?t="+new Date().getTime(), function....);
于 2012-12-22T16:05:09.087 回答