Javascript - переместить изображение вправо - PullRequest
1 голос
/ 19 июня 2011

Это функция, которая должна медленно перемещать изображение вправо, она не работает ... что я испортила?

<script type="text/javascript">
var userWidth = window.screen.width;
function moveRight(id, speed) {
    var pp = document.getElementById(id);
    var right = parseInt(pp.style.left);
    var tim = setTimeout("moveRight(id, speed)",50);
    right = right+speed;  // move
    if (right > window.screen.height / 2)
    {
        right=0;
        pp.style.left = right+"px";
    }
}
</script>

1 Ответ

4 голосов
/ 19 июня 2011

Похоже, id и speed не передаются в moveRight().Когда они в строке, как у вас, они не будут оценены.Посмотрите на это, кажется, делает свое дело.Я немного урезал его.

<div id="test" style="width: 50px; height: 50px; left: 0px; background-color: #000; position: absolute;">&nbsp;</div>

<script type="text/javascript">

    function moveRight(id, speed) {

        var pp = document.getElementById(id);
        var right = parseInt(pp.style.left) || 0;

        right += speed;  // move
        pp.style.left = right + "px";

        var move = setTimeout(function() {
            moveRight(id, speed);
        }, 50);

    }

    moveRight('test', 1);

</script>

Jsfiddle для игры.Вы можете настроить его по своему вкусу.

...