js运动事件函数详解

前端之家收集整理的这篇文章主要介绍了js运动事件函数详解前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

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

HTML

in the family pet.Cats ancestors is presumably desert cats

CSS布局样式省略

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

javascript

函数封装部分

<div class="jb51code">
<pre class="brush:js;">
//根据类名和父对象ID获取属性节点,解决getelementsByClass对浏览器的兼容性问题

function getbyclass(classname,parent){

//传入ID<a href="https://www.jb51.cc/tag/huoqu/" target="_blank" class="keywords">获取</a>父节点,如果该参数为空就为document

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

//定义一个空数组来存放<a href="https://www.jb51.cc/tag/shuxing/" target="_blank" class="keywords">属性</a>节点

var els=[];

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

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

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

for(var i=0;i<elements.length;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);
}

页面初始化函数方法调用

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

//给所有的div.img<a href="https://www.jb51.cc/tag/tianjia/" target="_blank" class="keywords">添加</a>鼠标移入,鼠标移出事件

for(var i=0;i<imgdog.length;i++){

imgdog[i].onmouSEOver=function(){
var obj=this.children[1];
MoveJason(obj,{"height":376,"width":206},5,30,function(){//缓冲动画的函数调用,当执行完宽高值的缓冲变化,再回调函数执行透明度缓冲变化。以下同理,可以多层嵌套实现多个回调。
MoveJason(obj,{"opacity":30},30);
});
}
imgdog[i].onmouSEOut=function(){
var obj=this.children[1];
MoveJason(obj,{"height":0,"width":0},function(){
MoveJason(obj,{"opacity":80},30);
});
}
}

}

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

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

原文链接:https://www.f2er.com/js/44984.html

猜你在找的JavaScript相关文章