0

我有几个文件,我正在从中提取次要文本(最多一个单词),然后用另一个脚本对其进行样式化。

目前,它们按应有的方式加载和显示。但是,文本文件会随机更新,因此我希望重新加载它们,然后将后续脚本再次应用于它们。我尝试了不同的 setTimeout 和 setInterval 命令,但我认为问题在于我的放置或使用。经过几个小时的研究,我确定只是语法不合适。

这在本地运行,但通过一个像远程一样执行脚本的程序来拉取。(没有跨域问题)

这是一个示例片段,它提取文件并加载到后续脚本读取以显示的 html:

$(function follow_pull() {
        $.ajax({
            url : "most_recent_follower.txt",
            dataType: "text",
            success : function (data) {
                $("#follow").append(data).serialize();
            },
            setTimeout(fuction(){
                follow_pull()
            }, 10000);
        });
}); 

这是将这些文件加载​​到脚本中以显示的段:

$(window).ready(function ledload() {
var options = {
        pixelSize: 5, 
        stepDelay: 62, 
        horizontalPixelsCount:650,
        verticalPixelsCount:5,
        pixelRatio: 0.8,
        pathToPixelImage: 'ticker/pixel.png',
        backgroundColor: '#000',
        disabledPixelColor : '#020202',
        enabledPixelColor: '#ff522b'
    };
    $('.canvasld, .crl').leddisplay($.extend(options, {pixelSize: 3}));
        },
            setTimeout(fuction(){
                ledload()
            }, 10000););    

任何方向表示赞赏。如果需要,我可以发布整个文件,但我认为有人会得到我正在做的事情并且知道如何最好地指导我。

对于上下文,我正在使用一个脚本来获取文本,让它看起来像一个 LED 并像一个股票行情一样滚动。这被用于 Twitch 上的广播公司。

4

3 回答 3

0

首先,我会ledload()退出$window.ready(). 这样,它可以通过它的名字来引用。另外,我很确定您不需要$(...)该函数的包装器follow_pull()...

function ledload() {
    var options = {
        pixelSize: 5, 
        stepDelay: 62, 
        horizontalPixelsCount:650,
        verticalPixelsCount:5,
        pixelRatio: 0.8,
        pathToPixelImage: 'ticker/pixel.png',
        backgroundColor: '#000',
        disabledPixelColor : '#020202',
        enabledPixelColor: '#ff522b'
    };
    $('.canvasld, .crl').leddisplay($.extend(options, {pixelSize: 3}));
}

function follow_pull() {    
    $.ajax({
        url : "most_recent_follower.txt",
        dataType: "text",
        success : function (data) {
            $("#follow").append(data).serialize();
            ledload();

            setTimeout(function(){
                follow_pull();
            }, 10000);
        }
    });
}; 

follow_pull()ledload()成功获取数据时调用。然后它会设置一个 10 秒的延迟,然后再重新开始。

如果您仍然想ledload在 上运行$(window).ready(),您也可以添加这一行:

$(window).ready(ledload);

PS我不明白.serialize()在做什么......这应该被传递到ledload()吗?

于 2018-07-16T21:02:35.937 回答
0

你在正确的轨道上,但你需要setTimeouts稍微移动一下,像这样:

$(function follow_pull() {
    $.ajax({
        url : "most_recent_follower.txt",
        dataType: "text",
        success : function (data) {
            $("#follow").append(data).serialize();
            setTimeout(fuction(){
                follow_pull()
            }, 10000);
        },
    });
}); 

这样,一旦数据加载成功,follow_pull10秒后会再次调用。

另一方面,您需要像这样移动它:

$(window).ready(function ledload() {
    var options = {
        pixelSize: 5,
        stepDelay: 62,
        horizontalPixelsCount: 650,
        verticalPixelsCount: 5,
        pixelRatio: 0.8,
        pathToPixelImage: 'ticker/pixel.png',
        backgroundColor: '#000',
        disabledPixelColor: '#020202',
        enabledPixelColor: '#ff522b'
    };
    $('.canvasld, .crl').leddisplay($.extend(options, {
        pixelSize: 3
    }));

    setTimeout(fuction() {
        ledload()
    }, 10000);
});

AJAX 就绪函数只接受一个参数,但您将 setTimeout 作为第二个参数传递,因此它被忽略了。

于 2018-07-16T21:02:47.340 回答
0

因此,查看您在评论中提供的内容,我找到了一种使其正常工作的方法。首先,是下面的html。以下是不同之处:

  • 我创建了一个新元素<div class="led"></div>。我还将.crlcss 赋予了该元素,而是制作了.crlhave display: none。这是因为该.leddisplay函数获取元素并将其替换为它自己的 HTML 以呈现 LED。因此,您需要将用于存储信息的信息与用于渲染div信息的信息分开。div(我建议只使用 JS 变量来存储该信息,但我不是试图重写你的代码,只是试图让它工作。)
  • 但是,如何将文本输入到 LED 显示屏中呢?你可以输入你想要的文本作为.leddisplay函数的第二个参数。你可以看到我是如何做到的postload()
  • 要更新您的信息,您使用的是append(). 这会添加到 div 中,但您想更新它们,所以我将每个.append()替换.text()为替换文本而不是添加到它。
  • 最后,解决方案的核心。该leddisplay插件无法更新 LED。所以你必须这样'destroy'做,然后重新运行它,就像我setTimeout()postload(). 但就其本身而言,每 10 秒重新开始滚动一次。所以我要做的是跟踪当前位置,然后在重新运行它之后,我从那里恢复滚动。然而,为了使这项工作,我需要更新插件代码。HTML 下面是对此的解释。

HTML:

<head>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js"></script>
</head>
<style>
.led {
padding-top: 2px;
padding-bottom: 2px;
background-color: #444; 
}
.crl {
    display: none;
}
</style>
<div class="top-bar"></div>
<div class="crl">Newest Subscriber - <span id="sub"></span>    
LAST DONATION - <span id="donation"></span>    
LATEST BITS - <span id="bits"></span>    
rECENT FOLLOWEr - <span id="follow"></span>    
Sub Goal - <span id="subgoal"></span> / 80</div>
<div class="led"></div>
<div class="bottom-bar"></div>

<script type="text/javascript">
$.ajaxSetup({
  async: false,
  cache: false
 });
$(function follow_pull() {
        $.ajax({
            url : "most_recent_follower.txt",
            dataType: "text",
            success : function (data) {
            console.log(data);          
                $("#follow").text(data);
            setTimeout(function(){
            follow_pull()
            }, 10000);
        },
    });
}); 
$(function donator_pull() { 
        $.ajax({
            url : "most_recent_donator.txt",
            dataType: "text",
            success : function (data) {
            console.log(data);          
                $("#donation").text(data);
            setTimeout(function(){
            donator_pull()
            }, 10000);
        },
    });
}); 
$(function cheerer_pull() {     
        $.ajax({
            url : "most_recent_cheerer.txt",
            dataType: "text",
            success : function (data) {
            console.log(data);          
                $("#bits").text(data);
            setTimeout(function(){
            cheerer_pull()
            }, 10000);
        },
    });
}); 
$(function subscriber_pull() {  
        $.ajax({
            url : "most_recent_subscriber.txt",
            dataType: "text",
            success : function (data) {
            console.log(data);          
            $("#sub").text(data);
            setTimeout(function(){
            subscriber_pull()
            }, 10000);
        },
    });
}); 
$(function count_pull() {       
        $.ajax({
            url : "total_subscriber_count.txt",
            dataType: "text",
            success : function (data) {
            console.log(data);
                $("#subgoal").text(data);
           setTimeout(function(){
            count_pull()
            }, 10000);
        },
    });
}); 
$(function ledload() {
$.getScript( "ticker/jquery.leddisplay.js", function( data, textStatus, jqxhr ) {
  console.log( data ); // Data returned
  console.log( textStatus ); // Success
  console.log( jqxhr.status ); // 200
  console.log( "Load was performed." );
    }); 
});
$(function postload() {
    var options = {
            pixelSize: 5, 
            stepDelay: 62, 
            horizontalPixelsCount:650,
            verticalPixelsCount:5,
            pixelRatio: 0.8,
            pathToPixelImage: 'ticker/pixel.png',
            backgroundColor: '#000',
            disabledPixelColor : '#020202',
            enabledPixelColor: '#ff522b'
        };
        $(".led").leddisplay($.extend(options, {
            pixelSize: 3
        }), $('.crl').text());

        setTimeout(function () {
            //get the current position
            var x = $(".led").leddisplay('getCurrentPosition')

            //destroy the led setup
            $('.led').leddisplay('destroy');

            //create it again
            postload();

            //set the position to where it left off at
            $(".led").leddisplay('setCurrentPosition', x)
        }, 10000);
});
</script>

customMethods在插件内部,朝底部寻找。我向它添加了另外 2 个方法:getCurrentPositionand setCurrentPosition,所以它应该如下所示:

jquery.leddisplay.js,自定义方法:

var customMethods = {
    init: function(){
        var _arg = arguments;
        return this.each(function() {
            var $this = $(this);
            if ($this.data('leddisplay'))
                return;

            $this.data('leddisplay', true);
            var methods = resolveMethods(this);
            methods.init.apply($this, _arg);
        });
    },
    destroy: function(){
        var _arg = arguments;
        return this.each(function() {
            var $this = $(this);
            if (!$this.data('leddisplay'))
                return;

            $this.data('leddisplay', null);
            var methods = resolveMethods(this);
            methods.destroy.apply($this, _arg);
        });
    },
    start: function(){

    },
    stop: function(){

    },
    getCurrentPosition: function(){
        return $(this).data('currentPosition');
    },
    setCurrentPosition: function(x){
        $(this).data('currentPosition', x);
    }
}

进行这些更改后,它应该可以按预期工作。

于 2018-07-17T16:12:12.237 回答