从同一个函数中调用函数

问题描述 投票:3回答:4

我正在将一些JavaScript代码转换为jQuery并且已经停止了,Heres代码...... HTML:

<div id="text"></div>

JavaScript的:

keywords = [ "one", "two", "three"]
var allowed = true;
function ChangeText ( ) {
   if(allowed)
   {
      var keyword = keywords[ Math.floor( Math.random() * keywords.length ) ]
      document.getElementById( "text" ).innerHTML = keyword;
   }
   setTimeout( "ChangeText()", switchTime );
} 
ChangeText();

jQuery的:

var changeAllowed = true;
$(document).ready(function ChangeText() {
   if(changeAllowed)
   {
      $("#text").fadeOut(500);
      var keyword = keywords[ Math.floor( Math.random() * keywords.length ) ];
      $("#text").text(keyword).fadeIn(1000);
   };
   setTimeout( "ChangeText()", 2000 );
});
ChangeText();

它应该做的是将文本淡出然后每隔2秒左右用一个新字符串(它在刷新时执行),jQuery效果正常工作,它似乎是setTimeout()或者我没有命名功能正常。

javascript jquery settimeout
4个回答
2
投票

UPDATE

当显示队列落后时,我的第一个解决方案失去了同步。这是使用回调的更新代码,因此时间总是正确的,以及test fiddle

var changeAllowed = true;
var keywords = ["test1", "test2", "test3", "test4", "test5"];
var hide = true;

var toggleTextFade = function() {
    if(changeAllowed) {
        var keyword =keywords[Math.floor(Math.random() * keywords.length)];

        $("#text").text(keyword).fadeIn(1000,null,function(){
            $("#text").fadeOut(500,null,toggleTextFade)});
    }               
};


$(document).ready(toggleTextFade);

7
投票

将字符串传递给setTimeout将从全局范围进行评估,其中未定义函数。直接传递它,以便它将从函数的范围进行评估,其中定义了函数(显然):

setTimeout( ChangeText, 2000 );

4
投票
setTimeout( arguments.callee, 2000 );

arguments.callee是函数的“自我指针”。最大的优点是它可以与匿名函数和命名函数一起使用。所以,对于jQuery:

var changeAllowed = true;
var keywords      = [anything];

$(document).ready(function () {
   if(changeAllowed) {
      var keyword = keywords[ Math.floor( Math.random() * keywords.length ) ];
      $("#text").fadeOut(500).text(keyword).fadeIn(1000);
   };
   setTimeout(arguments.callee, 2000 );
});

注意:这个答案来自2008年。如今,正确的方法已经改变了。如评论中所述,您将使用命名函数表达式(NFE),如下所示:

var changeAllowed = true;
var keywords      = [anything];

$(document).ready(function fadeKeyword() {
   if(changeAllowed) {
      var keyword = keywords[ Math.floor( Math.random() * keywords.length ) ];
      $("#text").fadeOut(500).text(keyword).fadeIn(1000);
   };
   setTimeout(fadeKeyword, 2000 );
});

arguments.callee仍将在非严格模式下工作,但严重时会导致错误。


3
投票

使用它没有parens和引号:setTimeout(ChangeText, 2000 );

© www.soinside.com 2019 - 2024. All rights reserved.