Javascript 动态添加 HTML

标签 javascript html

请看下面的代码,只移动最后一张图片。 http://jsfiddle.net/u8Bg3/

但是第二个有效 http://jsfiddle.net/u8Bg3/1/

正如 Er144 所指出的,即使这也适用于 jquery http://jsfiddle.net/u8Bg3/14/

我还发现 appendchild 有效但 innerhtml 无效

两者之间的区别在于,第一个 html 退出,第二个 html 是动态创建的

HTML

<body>
    <div class="racetrack" id="racetrack"></div>
    <div id="track-tmpl" class="hide">
        <div class="track"><div id="player{{ x }}" class="runner"></div></div>
    </div>
</body>

JS

var position = [0,40,80,120,80],
    racetrack = document.getElementById('racetrack');
    track_tmpl = document.getElementById('track-tmpl').innerHTML;


function Players(ele, ptimeout)
{
    this.el = ele;
    this.i = 0;
    this.iterations = 0;
    this.stop = 0;
    this.timeout = ptimeout;
    this.position = 0;

    this.animate = function(){
        if(this.i !== 0){
            this.move((this.position + 5), this.i);
        }
        if(!this.stop){
            if(this.i < 5){
                setTimeout(function(_this){             
                    _this.i++;
                    _this.animate();
                },this.timeout,this);
            }
            if(this.i==5){
                this.iterations ++;
                if(this.iterations < 50){
                    this.i = 0;
                    this.animate();
                }
                else{
                    this.el.style.backgroundPosition = '120px 0px';
                }
            }
        }
    };


    this.start = function(){
        this.stop = 0;
        this.animate();
    };

    this.move = function(to,positionIndex){
        this.position = to;
        this.el.style.backgroundPosition = '-'+position[positionIndex]+'px 0px';
        this.el.style.webkitTransform = 'translate('+to+'px)';
        this.el.style.mozTransform = 'translate('+to+'px)';
    }
}

function Game(noOfPlayers){

    this.noOfPlayers = noOfPlayers;

    this.players = new Array();

    for (var i = 0; i < this.noOfPlayers ; i++){
        racetrack.innerHTML = racetrack.innerHTML + track_tmpl.replace('{{ x }}', i);
        this.players.push(new Players(document.getElementById('player' + i), (120 + i)));
        /* issue here with dynamic added content*/
    }


    this.start = function(){
        for (var i = 0; i < this.noOfPlayers; i++){
            this.players[i].start();
        }
    };
}

var game = new Game(3);
game.start();

为什么在动态添加的 html 中只有最后一个移动

最佳答案

问题在于在 for 循环内创建 player(n) 对象以及使用 `+=' 对 innerHTML 进行赋值。修改后的 fiddle :http://jsfiddle.net/u8Bg3/15/工作正常。为一个好问题干杯!

  var finalized_tracks= "" ;
    for (var i = 0; i < this.noOfPlayers ; i++){
    finalized_tracks +=  track_tmpl.replace('{{ x }}', i);
    }
  racetrack.innerHTML = racetrack.innerHTML + finalized_tracks;

    for (var i = 0; i < this.noOfPlayers ; i++){
  this.players.push(new Players(document.getElementById('player'+ i),(120+i)));
    }

关于Javascript 动态添加 HTML,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21405460/

相关文章:

javascript - 针对 Drupal 7 中的特定错误

javascript - 当结构具有两个以上参数时,带有 array.push() 的 Solidity 函数不起作用

javascript - speechSynthesis API 不工作

html - 如何默认检查 Blazor 中的 InputRadio 单选按钮

javascript - 我如何获得文本区域的高度

javascript - 将信息传递到 jQuery ajax 响应处理函数中

javascript - axios get 请求中出现意外 token

exception - iOS UIWebView DOM异常18如何排查?

html - 类似 Facebook 的 friend 选择复选框

html - 根据浏览器窗口大小应用不同的 CSS 样式表——我找不到任何确定的东西