问答详情
源自:2-1 JS速度动画

为什么同样设置的速度是10px,移进移出的速度为什么不一样?

<!DOCTYPE html>

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

    <title>速度动画!!!测试</title>

    <style>

        #div1 {

           

            background-color: red;

            width: 200px;

            height: 200px;

            position: relative;

            left: -200px;

            top: 0;

        }


            #div1 span {

                width: 20px;

                height: 50px;

                background: blue;

                position: absolute;

                left: 200px;

                top: 75px;

            }

    </style>

    <script>

        window.onload = function () {

            var oDiv = document.getElementById('div1');

            oDiv.onmouseover = function () {

                startMove();

            }

            oDiv.onmouseout = function () {

                startMove1();

            }

 }

            var timer = null;

            function startMove() {

                clearInterval(timer);

                var oDiv = document.getElementById('div1');

                timer = setInterval(function () {

                    if (oDiv.offsetLeft>0) {

                        clearInterval(timer);

                    }

                    else {

                        oDiv.style.left = oDiv.offsetLeft+10+'px';

                    }

                }, 30)

            }

            function startMove1() {

                clearInterval(timer);

                var oDiv = document.getElementById('div1');

                timer = setInterval(function () {

                    if (oDiv.offsetLeft< -100) {

                        clearInterval(timer);

                    }

                    else {

                        oDiv.style.left = oDiv.offsetLeft -10+ 'px';

                    }


                }, 30);


            }

    </script>

</head>

<body>

    <div id="div1">

        <span id="share">分享!</span>

    </div>

</body>

</html>


提问者:weibo_张张张张张大仙呀_03578611 2016-08-05 11:48

个回答

  • 异择Y
    2016-08-05 13:47:48

    在最前面清空一下样式。

    *{

    margin:0;

    padding:0;