ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

链式运动

2021-07-08 10:34:58  阅读:143  来源: 互联网

标签:oDiv cur move ele 链式 var 运动 speed


<!DOCTYPE html> <html lang="en">
<head>     <meta charset="UTF-8">     <meta http-equiv="X-UA-Compatible" content="IE=edge">     <meta name="viewport" content="width=device-width, initial-scale=1.0">     <title>Document</title>     <style>         * {             margin: 0;             padding: 0;         }
        .a {             width: 100px;             height: 100px;             background-color: pink;             position: absolute;             left: 0;         }     </style> </head>
<body>     <div class="a"></div>     <script>         var oDiv = document.querySelector('.a')         move(20, 1300, oDiv, 'left', function () {             move(20, 600, oDiv, 'top', function () {                 move(20, 0, oDiv, 'left', function () {                     move(20, 0, oDiv, 'top')                 })             })         })         function move(speed, end, ele, attr, cb) {             // var cur = ele.offsetLeft;得到的是数字             // var cur = ele.style.left;得到的是一个字符串  px             // 实际上只有行内样式可以被读取                var cur = parseInt(getStyle(ele, attr));             var speed = end > cur ? speed : -speed;             var t = setInterval(function () {                 cur += speed;                 ele.style[attr] = cur + 'px'                 // 定时器结束的条件                 if (Math.abs(cur - end) < Math.abs(speed)) {                     cur = end                     ele.style[attr] = cur + 'px'                     clearInterval(t)                     //运动之后要做什么用一个函数包起来                     //如果cb传参,才执行                     if (cb) {                         cb()                     }                     // 逻辑与运算  见假即短路                     // cb&&cb()                 }             }, 50)         }         //获取css样式的兼容写法函数         function getStyle(ele, attr) {             if (window.getComputedStyle) {                 return getComputedStyle(ele)[attr]             }             return ele.currentStyle[attr]         }     </script> </body>
</html>

标签:oDiv,cur,move,ele,链式,var,运动,speed
来源: https://www.cnblogs.com/gyjjjjj/p/14984913.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有