首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >JS-缓冲运动基础结构

JS-缓冲运动基础结构

作者头像
xing.org1^
发布2018-10-10 11:20:43
8880
发布2018-10-10 11:20:43
举报
文章被收录于专栏:前端说吧前端说吧
<!DOCTYPE html>
<html>

    <head>
        <meta charset="UTF-8">
        <title>缓冲运动2</title>
        <style type="text/css">
        a{display: block;}
        input[type='button']{
            margin-top: 5px;
        }
            .div {
                width: 100px;
                height: 100px;
                background-color: red;
                position: absolute;
                left: 0;
                top: 200px;
                cursor: pointer;
            }
            .div2{
                width: 1px;
                height: 1200px;
                position: absolute;
                left: 300px;
                top: 0;
                background-color: blueviolet;
                /*用这个标杆,发现div1并没有走到300的准确位置,原因是?*/
            }
        </style>
        <script type="text/javascript">
        window.onload = function(){
            var oBtn = document.getElementById('btn');
        oBtn.onclick = function(){
            start();
        }
        }
        function start(){
        var oDiv = document.getElementById('div');
            setInterval(function(){
                var speed = Math.ceil((300-oDiv.offsetLeft)/10);
                //300,是自己定义的他要停止的位置值,
                //除以10 是必须的,这样就能有效地成倍地降低速度值,注意,更改10的值,可以更改速度,这个10所在分母位置的数值越大,速度越小。
//                var speed = Math.ceil((300-oDiv.offsetLeft)/10);
                //如果整除不了,会有0.5px,有了小数点,计算机会直接删掉小数点后的数字,导致物体运动不到准确位置。所以最后,用math的ceil方法,向上取整;floor方法,向下取整。
                //因为向左走向右走是不确定的,所以用三元判断的方法,如下:
                speed = speed>0?Math.ceil(speed):Math.floor(speed);
                //但凡遇到缓冲运动,一定要取整
                oDiv.style.left = oDiv.offsetLeft+speed+'px';
                document.title = oDiv.offsetLeft+','+speed;//用以检查、调试运动点是否正常
            },30);
        }
        
        </script>
    </head>

    <body>
        <p>关键点:</p>
        <a>距离大,速度大</a>,,,
        <a>距离小,速度小</a>
        <a>距离和速度成正比</a>
        <p style="color: brown;">关键点:遇到“缓冲运动”,一定要取整</p>
        <input type="button" value="运动" id="btn" />
        <div class="div" id="div"></div>
        <div class="div2"></div>
    
    </body>

</html>

课程来源路径:智能社得开发课程:https://ke.qq.com/webcourse/index.html#course_id=152997&term_id=100174752&taid=766913655494053&vid=v14127nxshc

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018-09-25 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档