js实现类似jquery里animate动画效果的方法


Posted in Javascript onApril 10, 2015

本文实例讲述了js实现类似jquery里animate动画效果的方法。分享给大家供大家参考。具体分析如下:

该实例可实现鼠标移上,先宽度变化,再高度变化,最后透明度变化,鼠标移出,再依次变回去的效果。

要点一:

startrun(obj,attr,target,fn)
box.onmouseover = function(){
startrun(box,"width",200,function(){
startrun(box,"height",200,function(){
startrun(box,"opacity","100")
});
});
}

如上面,函数也可以做为参数使用,就可以达到先执行某个动作,再执行某个动作的效果了。

要点二:

if(cur == target){
clearInterval(obj.timer);
if(fn){
fn();
}
}

当运动到达目标点,关闭定时器,然后就可以执行新的函数了。

最后,上代码:

<!DOCTYPE html>
<html>
<head>
<meta charset="gb2312" />
<title>无标题文档</title>
<style>
<!--
body{margin:0; padding:0; font:12px/1.5 arial;}
#box{width:100px; height:100px; position:absolute;
background:#06c; left:0;filter:alpha(opacity=30); opacity:0.3;}
-->
</style>
<script>
<!--
function getstyle(obj,name){
 if(obj.currentStyle){
  return obj.currentStyle[name];
 }else{
  return getComputedStyle(obj,false)[name];
 }
}
window.onload = function(){
 var box = document.getElementById("box");
 box.onmouseover = function(){
  startrun(box,"width",200,function(){
   startrun(box,"height",200,function(){
    startrun(box,"opacity","100")
   });
  });
 }
 box.onmouseout = function(){
  startrun(box,"height",100,function(){
   startrun(box,"width",100,function(){
    startrun(box,"opacity","30");
   });
  });
 }
}
function startrun(obj,attr,target,fn){
 clearInterval(obj.timer);
 obj.timer = setInterval(function(){
  var cur = 0;
  if(attr == "opacity"){
   cur = Math.round(parseFloat(getstyle(obj,attr))*100);
  }else{
   cur = parseInt(getstyle(obj,attr));
  }
  var speed = (target-cur)/8;
  speed = speed>0?Math.ceil(speed):Math.floor(speed);
  
  if(cur == target){
   clearInterval(obj.timer);
   if(fn){
    fn();
   }
  }else{
   if(attr == "opacity"){
    obj.style.filter = "alpha(opacity="+(cur+speed)+")";
    obj.style.opacity = (cur+speed)/100;
   }else{
   obj.style[attr] = cur + speed + "px";
   }
  }
 },30)
}
//-->
</script>
</head>
<body>
<div id="box">
</div>
</body>
</html>

希望本文所述对大家的javascript程序设计有所帮助。

Javascript 相关文章推荐
在浏览器中获取当前执行的脚本文件名的代码
Jul 19 Javascript
判断对象是否Window的实现代码
Jan 10 Javascript
js数组的基本用法及数组根据下标(数值或字符)移除元素
Oct 20 Javascript
基于jquery插件制作左右按钮与标题文字图片切换效果
Nov 07 Javascript
JS两种类型的表单提交方法实例分析
Nov 28 Javascript
JavaScript获取服务器端时间的方法
Nov 29 Javascript
VUE中使用Vue-resource完成交互
Jul 21 Javascript
Mac中安装nvm的教程分享
Dec 11 Javascript
angularjs使用gulp-uglify压缩后执行报错的解决方法
Mar 07 Javascript
Angular 封装并发布组件的方法示例
Apr 19 Javascript
jQuery md5加密插件jQuery.md5.js用法示例
Aug 24 jQuery
javascript 数组(list)添加/删除的实现
Dec 17 Javascript
js实现类似新浪微博首页内容渐显效果的方法
Apr 10 #Javascript
javascript中关于&amp;&amp; 和 || 表达式的小技巧分享
Apr 10 #Javascript
js简单的点击返回顶部效果实现方法
Apr 10 #Javascript
浅谈JavaScript正则表达式分组匹配
Apr 10 #Javascript
JavaScript实现基于Cookie的存储类实例
Apr 10 #Javascript
JavaScript 变量、作用域及内存
Apr 08 #Javascript
JavaScript Function函数类型介绍
Apr 08 #Javascript
You might like
两个开源的Php输出Excel文件类
2010/02/08 PHP
PHP用GD库生成高质量的缩略图片
2011/03/09 PHP
php从右向左/从左向右截取字符串的实现方法
2011/11/28 PHP
PHP内存缓存Memcached类实例
2014/12/08 PHP
php使用pecl方式安装扩展操作示例
2019/08/12 PHP
php查看一个变量的占用内存的实例代码
2020/03/29 PHP
javascript replace方法与正则表达式
2008/02/19 Javascript
extjs grid设置某列背景颜色和字体颜色的方法
2010/09/03 Javascript
JS解决url传值出现中文乱码的另类办法
2013/04/08 Javascript
基于jQuery实现复选框的全选 全不选 反选功能
2014/11/24 Javascript
jQuery中[attribute^=value]选择器用法实例
2014/12/31 Javascript
浅析node连接数据库(express+mysql)
2015/11/30 Javascript
基于jQuery实现交互体验社会化分享代码附源码下载
2016/01/04 Javascript
javascript匀速动画和缓冲动画详解
2016/10/20 Javascript
websocket+node.js实现实时聊天系统问题咨询
2017/05/17 Javascript
深入探究angular2 UI组件之primeNG用法
2017/07/26 Javascript
浅谈webpack组织模块的原理
2018/03/10 Javascript
jQuery扩展方法实现Form表单与Json互相转换的实例代码
2018/09/05 jQuery
vue学习笔记之Vue中css动画原理简单示例
2020/02/29 Javascript
js事件机制----捕获与冒泡机制实例分析
2020/05/22 Javascript
在Django的URLconf中使用多个视图前缀的方法
2015/07/18 Python
Python中的字符串替换操作示例
2016/06/27 Python
python多进程读图提取特征存npy
2019/05/21 Python
Python实现时间序列可视化的方法
2019/08/06 Python
Python任务调度模块APScheduler使用
2020/04/15 Python
Python自定义聚合函数merge与transform区别详解
2020/05/26 Python
python如何爬取网页中的文字
2020/07/28 Python
如何解决flask修改静态资源后缓存文件不能及时更改问题
2020/08/02 Python
python绘图模块之利用turtle画图
2021/02/12 Python
canvas实现扭蛋机动画效果的示例代码
2018/10/17 HTML / CSS
遗体告别仪式答谢词
2014/01/23 职场文书
先进班级集体事迹材料
2014/01/30 职场文书
2014年幼儿园安全工作总结
2014/11/10 职场文书
团组织关系介绍信
2019/06/24 职场文书
八年级作文之感恩
2019/11/22 职场文书
win10系统xps文件怎么打开?win10打开xps文件的两种操作方法
2022/07/23 数码科技