js浮动运动函数html,js运动事件函数详解

本文实例为大家分享了js运动事件函数,供大家参考,具体内容如下

HTML

The Dog

Split between cat,belong to the cat family,cat,cat,is the world's more widely

in the family pet.Cats ancestors is presumably desert cats

labrador.jpg

拉布拉多

Labrador

拉布拉多猎犬因原产地在加拿大的纽芬兰与拉布拉多省而得名。拉布拉多犬是一种中大型犬类,个性忠诚、大气、憨厚、温和、阳光、开朗、活泼,智商极高,也对人很友善,是非常适合被选作经常出入公共场合的导盲犬或地铁警犬及搜救犬和其他工作犬的狗品种,跟哈士奇(西伯利亚雪撬犬)和金毛猎犬并列三大无攻击性犬类,拉布拉多智商位列世界犬类第七。

CSS布局样式省略

现在a.lookdog的样式我设为position:absolutely,宽高设为0。实现的特效:当鼠标移入div.img上,实现a.lookdog的宽高自动展开的缓冲动画,并且展开完毕后,透明度变低的遮罩背景图层。当然我们用css3也能实现这种特效,但是css3的坑是不完全支持IE浏览器,所以用javascript来实现运动缓冲动画是最理想的。

javascript

函数封装部分

//根据类名和父对象ID获取属性节点,解决getelementsByClass对浏览器的兼容性问题

function getbyclass(classname,parent){

//传入ID获取父节点,如果该参数为空就为document

var oParent=parent?document.getElementById(parent):document;

//定义一个空数组来存放属性节点

var els=[];

//定义一个数组存放父对象的所有子节点

var elements=oParent.getElementsByTagName("*");

//遍历所有子节点,根据类名把所有的子对象找出来,并且放在els数组内

for(var i=0;i

if(elements[i].className==classname){

els.push(elements[i]);

}

}

return els;

}

//根据对象要获取的属性名来得到属性值

function getStyle(obj,stylename){

//针对IE浏览器获取样式方法

if(obj.currentStyle){

return obj.currentStyle[stylename];

//针对其他浏览器获取样式方法

}else if(getComputedStyle(obj,false)){

return getComputedStyle(obj,false)[stylename];

}

}

//缓冲动画主函数,传参类型:(对象,jaso格式要改变的样式值(可多个),缓冲系数,执行周期时间(值越小速度越快,越大越慢),回调函数(是否有多次动画的播放,可有可无))

function MoveJason(obj,jason,average,cycle,continuefunction){

clearInterval(obj.timer);

obj.timer=setInterval(function(){

for(var stylename in jason){//针对多效果的缓冲动画

// obj.style[stylename]=jason[stylename];

// }

if(stylename=="opacity"){

var offvalue=Math.round(parseFloat(getStyle(obj,stylename))*100);

var speed=(jason[stylename]-offvalue)/average;

speed=speed>0?Math.ceil(speed):Math.floor(speed);

if(speed==0){

clearInterval(obj.timer);

if(continuefunction) continuefunction();//回调函数,判断是否有多次执行

}else{

obj.style[stylename]=(offvalue+speed)/100;

obj.style.filter="alpha(opacity:"+(offvalue+speed)+")";

}

}else{

var offvalue=parseInt(getStyle(obj,stylename));

var speed=(jason[stylename]-offvalue)/average;

speed=speed>0?Math.ceil(speed):Math.floor(speed);

if(speed==0){

clearInterval(obj.timer);

if(continuefunction) continuefunction();

}else{

obj.style[stylename]=offvalue+speed+"px";

}

}

}

},cycle);

}

页面初始化函数,方法调用

window.οnlοad=function(){

var imgdog=getbyclass("img","breedsdog");//在父对象breedsdog上找到所有的div.img

//给所有的div.img添加鼠标移入,鼠标移出事件

for(var i=0;i

imgdog[i].οnmοuseοver=function(){

var obj=this.children[1];

MoveJason(obj,{"height":376,"width":206},5,30,function(){//缓冲动画的函数调用,当执行完宽高值的缓冲变化,再回调函数执行透明度缓冲变化。以下同理,可以多层嵌套实现多个回调。

MoveJason(obj,{"opacity":30},5,30);

});

}

imgdog[i].οnmοuseοut=function(){

var obj=this.children[1];

MoveJason(obj,{"height":0,"width":0},5,30,function(){

MoveJason(obj,{"opacity":80},5,30);

});

}

}

}

鼠标移入移出效果图如下,我多加个了几个div.img,可以看到等宽高变完,然后透明度发生变化。

45467c17a8ed7dcfc7beffb21b7ce149.gif

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值