五、多物体变宽
这里面要注意由于物体变多了,需要给每个物体各配备一个定时器,否则如果只有一个定时器的话,当鼠标在不同物体之间快速滑动时,不同的物体就会出现争抢的现象。所以timer前要加obj.
function changeWidth(obj,target) {//元素,目标值
clearInterval(obj.timer);//清除定时器防止嵌套调用
obj.timer=setInterval(function () {//设置定时器
var speed=(target-obj.offsetWidth)/8;//定义缓冲速度,目标值减当前值
speed=speed>0?Math.ceil(speed):Math.floor(speed);//缓冲速度一定要取整
if (obj.offsetWidth==target) {//判断物体当前宽度和目标值的关系,如果达到目标清除定时器
clearInterval(obj.timer);
} else {
obj.style.width=obj.offsetWidth+speed+'px';
}
},30)
}举例:用3个li来举例:
this参数指的就是对象自己。和前几次不同的是这次的定时器清空要对每个li分别清空。
六、多物体变透明度
涉及到透明度就要注意浏览器的兼容性问题。还有,透明度的初始值不能像上一个单独物体透明度初值那样设置一个,多物体的透明度初始值要分别设置,每个物体都有初始值。
function changeOpacity(obj,speed,target) {
clearInterval(obj.timer);//清除定时器,避免嵌套调用
obj.timer=setInterval(function () {
if (obj.alpha==target) {//如果透明度达到目标值,清除定时器
clearInterval(obj.timer);
} else {//当前透明度加上透明度变化的速度
obj.alpha=obj.alpha+speed;
obj.style.filter='alpha(opacity:'+obj.alpha+')';//IE浏览器
obj.style.opacity=obj.alpha/100;//火狐和谷歌
}
}, 30)
}下面用几个div举例子:
一、源码描述这是一款比较简单的企业管理系统源码,界面美观大方,功能简单,特别适合初学者学习研究,系统运行十分流畅,可以作为二次开发,同时也是可以帮助初学者增长知识的优秀代码。二、功能介绍主要功能:企业动态,产品介绍 ,免费下载,定制服务,该源码比较适合新手学习和二次开发使用。三、源码特点1、网站布局:采用目前最先进的布局方式DIV+CSS,符合W3C的标准和Web2.0的风格。2、程序设计模块化,
以上就是js动画学习(三)的内容,更多相关内容请关注PHP中文网(www.php.cn)!









