JS-缓冲运动-对联型悬浮框

简介: DOCTYPE html> 缓冲运动2 body{ height: 2000px; } .
<!DOCTYPE html>
<html>

    <head>
        <meta charset="UTF-8">
        <title>缓冲运动2</title>
        <style type="text/css">
        body{
            height: 2000px;
        }
            .div {
                width: 100px;
                height: 100px;
                background-color: darkslateblue;
                position: absolute;
                right: 0;
                /*bottom: 0;*/
                cursor: pointer;
            }
        </style>
        <script type="text/javascript">
        window.onscroll= function(){
            //1,给浏览器的滚动添加事件,onscollTop事件
            var oDiv = document.getElementById('div');
            var scrollTop = document.documentElement.scrollTop||document.body.scrollTop;
//            oDiv.style.top = (document.documentElement.clientHeight-oDiv.offsetHeight)/2+scrollTop+'px';
            //可视区域的高度减掉物体高度再加上向上滚动的高度
            starMove(parseInt((document.documentElement.clientHeight-oDiv.offsetHeight)/2+scrollTop));
            //除以2以后就一直抖,就用parseInt取整
        };
        var timer = null;
        function starMove(iTarget){
            var oDiv = document.getElementById('div');
            clearInterval(timer);
            timer = setInterval(function(){
                var speed = (iTarget-oDiv.offsetTop)/4;
                speed=speed>0?Math.ceil(speed):Math.floor(speed);
                if(oDiv.offsetTop==iTarget){
                    clearInterval(timer)
                }else{
                    document.title = iTarget;
                    document.getElementById('btn').value=oDiv.offsetTop;
                    oDiv.style.top = oDiv.offsetTop+speed+'px';
                }
            },30)
        }
        
        </script>
    </head>

    <body>
        <div class="div" id="div"></div>
    <input type="text" value="" id="btn" style="top: 0;
        right: 0;
        position: fixed;"/>
    </body>

</html>

课程链接:智能社的开发教程:https://ke.qq.com/webcourse/index.html#course_id=152997&term_id=100174752&taid=766913655494053&vid=v14127nxshc

目录
相关文章
|
JavaScript 前端开发
js 文字超出长度用省略号代替,鼠标悬停并以悬浮框显示
js 文字超出长度用省略号代替,鼠标悬停并以悬浮框显示
|
10月前
|
JavaScript 前端开发 Java
使用JavaScript实现小球自由落体运动
使用JavaScript实现小球自由落体运动
93 0
|
JavaScript
js基础笔记学习280蛇流畅运动
js基础笔记学习280蛇流畅运动
39 0
js基础笔记学习280蛇流畅运动
|
JavaScript
js基础笔记学习279初步完成贪吃蛇运动2
js基础笔记学习279初步完成贪吃蛇运动2
51 0
js基础笔记学习279初步完成贪吃蛇运动2
|
JavaScript
js基础笔记学习278初步完成贪吃蛇运动1
js基础笔记学习278初步完成贪吃蛇运动1
51 0
js基础笔记学习278初步完成贪吃蛇运动1
|
JSON JavaScript 前端开发
好程序员技术教程分享JavaScript运动框架
好程序员技术教程分享JavaScript运动框架,有需要的朋友可以参考下。 JavaScript的运动,即让某元素的某些属性由一个值变到另一个值的过程。如让div的width属性由200px变到400px,opacity属性由0.3变到1.0,就是一个运动过程。
1516 0
|
JavaScript 前端开发
javascript元素跟随鼠标在指定区域运动
原文:javascript元素跟随鼠标在指定区域运动 元素跟随鼠标在指定区域运动通常是用在商城图片的放大镜中,下面是完整的Demo: 鼠标区域 *{margin:0;padding:0;} .
804 0
|
JavaScript 前端开发
JS:“分享到”之类的悬浮框的运动原理(代码)
DOCTYPE html> 只传一个参数 .div { width: 100px; height: 100px; ...
845 0
|
JavaScript 前端开发
JS-运动基础——案例应用:淡入淡出效果
DOCTYPE html> 淡入淡出 .div { width: 100px; height: 100px; b...
772 0
|
JSON 数据格式
JS-完美运动框架(封装)
function getStyle(obj, name) { if(obj.currentStyle) { return obj.currentStyle[name]; } else { return getComputedS...
686 0