For loop does not allow setTimeout to execute

前端 未结 4 1133
不知归路
不知归路 2021-01-22 05:00

I have the below function that logs a character in a sentence passed to a function at a certain given time, have a look at the function below:

function print_st         


        
相关标签:
4条回答
  • 2021-01-22 05:15

    If you want the timer argument to act as an actual interval, use this:

    function print_string(param, timer) {
    
      for(var i = 0 ; i < param.length ; i++) {
    
        setTimeout((function(char){
    
          return function () {
    
            console.log(char);
    
          }
    
        })(param.charAt(i)), timer * i);  
      }
    }
    
    var str = print_string("hey there , whats up , hows the weather in Manhatten" , 500);
    

    Here is a fiddle.

    The confusion for you is that a for loop happens immediately, or as fast as the processor will allow it. When the setTimeout handler executes, it has a different scope to what you're probably expecting. The scope is no longer within the for loop (because that happened in a different tick of the processor) so the print variable is lost. In order to get around this, I'm using what is called a closure. I'm building a function on the fly, to print the specific variable that I need, and passing it as an argument to setTimeout.

    Read more about closures here.

    0 讨论(0)
  • 2021-01-22 05:37

    The difference of the two pieces of code is:
    In the first one you set the timer each time the timeout function is triggered.
    In the second case you set all the timers simultaneously (almost) in each "foreach" iteration, so the events fire the same time.
    You can prevent it by timer+=50.

    0 讨论(0)
  • 2021-01-22 05:38

    I'll try to exlain:

    You are passing a string with 30 characters to the function print_string so that the for loop will iterate and call setTimeout 30 times. After 50ms the first setTimeout callback will be called and will output the first char of your string. The variable strt_point will be incremented. Then the second setTimeout callback of your second for loop iteration will be called immediately and because strt_point is has already been incremented, the second char will be printed.

    The problem is that you have ONE variable strt_point for all iterations of the for loop so that all chars are printed after 50ms.

    0 讨论(0)
  • 2021-01-22 05:39

    I think you want something like this:

    var print_string = function ( param, interval ) {
      var
        i = 0,
        len = param.length,
        
        result = document.getElementById( 'result' ),
        
        // function called for every characters
        next = function () {
          // get the current character
          var char = param.charAt(i);
          
          // do what you want with them
          result.innerHTML += char;
          
          // if not the end of the string
          if ( ++i < len ) {
            // continue after the interval
            setTimeout( next, interval );
          }
        }
    
      next();
    }
    
    print_string( 'hey there , whats up , hows the weather in Manhatten!', 50 );
    <div id="result"></div>

    0 讨论(0)
提交回复
热议问题