效果展示:飞入的图片,滑动的弹窗
data:image/s3,"s3://crabby-images/b2875/b287549dfb356bfecae87224532b6b4c5bcd5c60" alt=""
*需求:根据鼠标进入方向,蒙层从相应的方向滑出,图片添加适当动画。
*解题思路:获取鼠标来自于什么方向,根据鼠标移入方向,添加蒙层效果。
*具体步骤:
1.获取鼠标的进入方向
var moveInWay=function($el,e){
var w=$el.outerWidth();
var h=$el.outerHeight();
var x=(e.pageX-$el.offset().left-(w/2))*(w>h?(h/w):1);
var y=(e.pageY-$el.offset().top-(h/2))*(h>w?(w/h):1);
return Math.round((((Math.atan2(y,x)*(180/Math.PI))+180)/90)+3)%4;
};
至于为什么这样可以获取到鼠标进入的方向,请参考:鼠标移入判断原理;简单讲就是判断当前目标元素属于哪个区域,这里就不做详细讲解了。
2. 使用方法
$(".itemList").on("mouseenter mouseleave",function(e) {
var direction = moveInWay($el,e);
dir =["top","right","bottom","left"];
if(e.type =="mouseenter"){
$("div").text("鼠标从"+dir[direction]+"方进入");
}else{
$("#div").text("鼠标从"+dir[direction]+"方离开");
}
});
3.具体demo
3.1 html片段:
data:image/s3,"s3://crabby-images/fcd4c/fcd4cadf0e600c22eb0d2889f42a68484ce3af51" alt=""
3.2 css样式:
data:image/s3,"s3://crabby-images/09cd9/09cd9ff5a5c7fd673178a198a5b1109a1804df8c" alt=""
3.3 js部分
①获取鼠标进入方向
data:image/s3,"s3://crabby-images/05598/05598dd7bac0d5ebfa08e06034f3de0492c56b44" alt=""
②定义动画开始位置(图片及蒙层)
data:image/s3,"s3://crabby-images/401ca/401ca627d313a3021f7aa5a3d7ab884136202e8d" alt=""
③鼠标进入及离开动画处理
data:image/s3,"s3://crabby-images/7766f/7766f9d93ecdc61a1af3315117577de0a8b4f3f2" alt=""
其实代码本身并不重要,重要的是思路,和实现的方式,希望对大家有帮助!!!
最后送上源码:
百度云盘链接:
http://pan.baidu.com/s/1kU4T5iR
提取码:
wq67
你也可以使用微信查看该文:
data:image/s3,"s3://crabby-images/dbfb7/dbfb7dafd150c2790cbcf283170d00af9bb732f9" alt=""
网友评论