原生JS封装animate运动框架的实例
2017-10-12 08:34
806 查看
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title></title> <style> div { width: 100px; height: 100px; background-color: pink; position: absolute; left: 0; top: 50px; border-radius: 50%; } </style> </head> <body> <button id="btn200">200</button> <button id="btn400">400</button> <div id="box"></div> </body> </html> <script> var btn200 = document.getElementById("btn200"); var btn400 = document.getElementById("btn400"); var box = document.getElementById("box"); btn200.onclick = function() { animate(box,{width: 200, top: 100,left: 200,opacity:40,zIndex:3},function(){alert("我来了")}); } btn400.onclick = function() { animate(box,{top:500,opacity:10}); } // 多个属性运动框架 添加回调函数 function animate(obj,json,fn) { // 给谁 json clearInterval(obj.timer); obj.timer = setInterval(function() { var flag = true; // 用来判断是否停止定时器 一定写到遍历的外面 for(var attr in json){ // attr 属性 json[attr] 值 //开始遍历 json // 计算步长 用 target 位置 减去当前的位置 除以 10 // console.log(attr); var current = 0; if(attr == "opacity") { current = Math.round(parseInt(getStyle(obj,attr)*100)) || 0; console.log(current); } else { current = parseInt(getStyle(obj,attr)); // 数值 } // console.log(current); // 目标位置就是 属性值 var step = ( json[attr] - current) / 10; // 步长 用目标位置 - 现在的位置 / 10 step = step > 0 ? Math.ceil(step) : Math.floor(step); //判断透明度 if(attr == "opacity") // 判断用户有没有输入 opacity { if("opacity" in obj.style) // 判断 我们浏览器是否支持opacity { // obj.style.opacity obj.style.opacity = (current + step) /100; } else { // obj.style.filter = alpha(opacity = 30) obj.style.filter = "alpha(opacity = "+(current + step)* 10+")"; } } else if(attr == "zIndex") { obj.style.zIndex = json[attr]; } else { obj.style[attr] = current + step + "px" ; } if(current != json[attr]) // 只要其中一个不满足条件 就不应该停止定时器 这句一定遍历里面 { flag = false; } } if(flag) // 用于判断定时器的条件 { clearInterval(obj.timer); //alert("ok了"); if(fn) // 很简单 当定时器停止了。 动画就结束了 如果有回调,就应该执行回调 { fn(); // 函数名 + () 调用函数 执行函数 } } },30) } function getStyle(obj,attr) { // 谁的 那个属性 if(obj.currentStyle) // ie 等 { return obj.currentStyle[attr]; // 返回传递过来的某个属性 } else { return window.getComputedStyle(obj,null)[attr]; // w3c 浏览器 } } </script>
以上这篇原生JS封装animate运动框架的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章推荐
- 原生JS实现风箱式demo,并封装了一个运动框架(实例代码)
- 原生JS实现风箱式demo,并封装了一个运动框架(实例代码)
- 原生js封装运动框架的示例讲解
- 原生JS实现图片无缝滚动方法(附带封装的运动框架)
- 用原生js封装运动框架
- 用原生JS对AJAX做简单封装的实例代码
- 原生js实现时间版运动框架
- 原生js 封装get ,post, delete 请求的实例
- 原生Js完美运动框架(缓冲运动和弹性运动)
- JS运动基础框架实例分析
- js 运动框架及实例
- 封装运动框架实战左右与上下滑动的焦点轮播图(实例)
- JS运动基础框架实例分析
- JS运动框架之分享侧边栏动画实例
- 原生js封装元素运动函数
- [js高手之路]封装运动框架实战左右与上下滑动的焦点轮播图
- 【原生JS组件】javascript 运动框架
- 包含缓冲和弹性运动的原生JS封装以及例子
- JS运动框架之分享侧边栏动画实例
- 原生js多动画同时运动框架(style属性多项同时改变)