for循环appendChild实时显示

for loop appendChild real time display

本文关键字:显示 实时 appendChild 循环 for      更新时间:2023-09-26

我想设置for循环来逐个打印消息,我只是延迟了console.log消息,appendChild消息将显示为for循环结束。我该怎么修。

以下是代码http://jsfiddle.net/wts8gb8g/

function createLogDiv(){
    if(document.getElementById("log") == null){
        var log = document.createElement("div");
        log.id = "log";
        document.body.appendChild(log);
        var css = document.createElement("style");
        css.type = "text/css";
        css.innerHTML = "#log {width: 400px;height: 200px;background: black;position: absolute;top: 0;opacity: 0.75;color: lime;overflow: auto;text-align: left;margin-top: 46px;}";
        document.body.appendChild(css);
    }
}
function log(str){
    var xx = document.createElement("div");
    xx.innerHTML=str+"</br>";
    document.getElementById("log").appendChild(xx);
    console.log(str);
}
function sleep(milliseconds){
  var start = new Date().getTime();
  for (var i = 0; i < 1e7; i++){
    if ((new Date().getTime() - start) > milliseconds){
      break;
    }
  }
}

createLogDiv();
for(var i=0;i<5;i++){
    log(i);
    sleep(500);

尝试将循环更改为:

createLogDiv();
for(var i=0;i<5;i++)
{
    setTimeout(function(x){log(x)},500*i,i);
}