html hover判断移出,根据鼠标移入移出方向,实现hover效果

首先,我们要判断鼠标移入对象的方向:

先获取该对象的左边距,然后通过判断鼠标距离上面、左面、右面、下面的值的最小值,来获取鼠标移入对象的方向。

JS代码:

;(function($){

$.fn.extend({

dirMove:function(){

var $outer=this;

var $mask=this.find("#mask");

var disL = $outer.offset().left;

var disT = $outer.offset().top;

var disR = disL + $outer.outerWidth();

var disB = disT + $outer.outerHeight();

$outer.hover(function(e){

Confirmdir(e);

},function(e){

Confirmdir(e);

});

function Confirmdir(e){ //确定具体鼠标移入对象的方向

var dirL = Math.abs(e.pageX - disL);

var dirT = Math.abs(e.pageY - disT);

var dirR = Math.abs(e.pageX - disR);

var dirB = Math.abs(e.pageY - disB);

var dir = Math.min(dirL,dirT,dirR,dirB);//取得最小值

if(e.type=="mouseenter"){

switch(dir){

case dirL:

mouseIn("left");

break;

case dirT:

mouseIn("top");

break;

case dirR:

mouseIn("right");

break;

case dirB:

mouseIn("bottom");

break;

}

}else{

switch(dir){

case dirL:

mouseOut("left");

break;

case dirT:

mouseOut("top");

break;

case dirR:

mouseOut("right");

break;

case dirB:

mouseOut("bottom");

break;

}

}

}

function mouseIn(dir){

switch(dir){

case "left":

$mask.css({"left":-$outer.outerWidth(),"top":0}).show().stop(true,true).animate({"left":0});

break;

case "top":

$mask.css({"left":0,"top":-$outer.outerHeight}).show().stop(true,true).animate({"top":0});

break;

case "right":

$mask.css({"left":$outer.outerWidth(),"top":0}).show().stop(true,true).animate({"left":0});

break;

case "bottom":

$mask.css({"left":0,"top":$outer.outerHeight}).show().stop(true,true).animate({"top":0});

break;

}

}

function mouseOut(dir){

switch(dir){

case "left":

$mask.stop(true,true).animate({"left":-$outer.outerWidth()});

break;

case "top":

$mask.stop(true,true).animate({"top":-$outer.outerHeight()});

break;

case "right":

$mask.stop(true,true).animate({"left":$outer.outerWidth()});

break;

case "bottom":

$mask.stop(true,true).animate({"top":$outer.outerHeight()});

break;

}

}

}

})

})(jQuery);

HTML代码:

$(".outer").each(function(){

$(this).dirMove();

})

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值