jquery判断鼠标移动方向--版本2
2016-12-07 10:52
429 查看
之前网上收集过一个判断鼠标移动方向的demo,但是实现过程相对比较复杂,涉及到一些函数计算。
链接地址:http://blog.csdn.net/jian_xi/article/details/53427435
下面这个版本的代码毕竟容易看懂,先上效果图:
html代码:
<div class="box">
<ul>
<li>
<img src="img/1.jpg">
<div class="cover">
<p class="info">fasdfhggadsg</p>
</div>
</li>
<li>
<img src="img/2.jpg">
<div class="cover">
<p class="info">fasdfhggadsg</p>
</div>
</li>
<li>
<img src="img/3.jpg">
<div class="cover">
<p class="info">fasdfhggadsg</p>
</div>
</li>
<li>
<img src="img/4.jpg">
<div class="cover">
<p class="info">fasdfhggadsg</p>
</div>
</li>
<li>
<img src="img/5.jpg">
<div class="cover">
<p class="info">fasdfhggadsg</p>
</div>
</li>
</ul>
</div>
css代码:
*{
margin: 0;
padding: 0;
}
.box{
width: 1200px;
height: 360px;
margin: 100px auto;
}
.box ul li{
list-style: none;
width: 230px;
height: 360px;
float: left;
margin-right: 10px;
position: relative;
overflow: hidden;
}
.box ul li img{
display: block;
}
.box ul li .cover{
width: 230px;
height: 360px;
background: url(img/new-bg.png);
position: absolute;
left: 230px;
top:0;
}
.box ul li .cover p{
font-size: 14px;
font-family: "微软雅黑";
text-align: center;
color: #fff;
margin-top: 120px;
}
js:
(function(){
var $li = $(".box ul li");
$li.hover(function(e){
move.call(this,e,true);
},function(e){
move.call(this,e,false);
});
function move(e,bool){
var liTop = $(this).offset().top;
var liLeft = $(this).offset().left;
var liBottom = liTop + $(this).height();
var liRight = liLeft + $(this).width();
//获取鼠标的坐标
var ev = e || window.event;
var pagex = ev.pageX;
var pagey = ev.pageY;
//获取鼠标距离四条边的距离
var jtop = Math.abs(pagey - liTop);
var jbottom = Math.abs(pagey - liBottom);
var jleft = Math.abs(pagex - liLeft);
var jright = Math.abs(pagex - liRight);
console.log(jleft+"--"+jtop)
//获取四个值中的最小值,判断进入的方向
var min = Math.min(jtop,jbottom,jleft,jright);
switch(min){
case jtop:
if(bool){
$(this).find(".cover").css({
top:"-360px",
left:0
}).stop().animate({
top:"0"
});
}else{
$(this).find(".cover").stop().animate({
top:"-360px"
});
}
break;
case jleft:
if(bool){
$(this).find(".cover").css({
left:"-360px",
top:0
}).stop().animate({
left:"0"
});
}else{
$(this).find(".cover").stop().animate({
left:"-360px"
});
}
break;
case jbottom:
if(bool){
$(this).find(".cover").css({
top:"360px",
left:0
}).stop().animate({
top:"0"
});
}else{
$(this).find(".cover").stop().animate({
top:"360px"
});
}
break;
case jright:
if(bool){
$(this).find(".cover").css({
left:"360px",
top:0
}).stop().animate({
left:"0"
});
}else{
$(this).find(".cover").stop().animate({
left:"360px"
});
}
break;
}
}
})();
以上为该效果的全部实现过程!
链接地址:http://blog.csdn.net/jian_xi/article/details/53427435
下面这个版本的代码毕竟容易看懂,先上效果图:
html代码:
<div class="box">
<ul>
<li>
<img src="img/1.jpg">
<div class="cover">
<p class="info">fasdfhggadsg</p>
</div>
</li>
<li>
<img src="img/2.jpg">
<div class="cover">
<p class="info">fasdfhggadsg</p>
</div>
</li>
<li>
<img src="img/3.jpg">
<div class="cover">
<p class="info">fasdfhggadsg</p>
</div>
</li>
<li>
<img src="img/4.jpg">
<div class="cover">
<p class="info">fasdfhggadsg</p>
</div>
</li>
<li>
<img src="img/5.jpg">
<div class="cover">
<p class="info">fasdfhggadsg</p>
</div>
</li>
</ul>
</div>
css代码:
*{
margin: 0;
padding: 0;
}
.box{
width: 1200px;
height: 360px;
margin: 100px auto;
}
.box ul li{
list-style: none;
width: 230px;
height: 360px;
float: left;
margin-right: 10px;
position: relative;
overflow: hidden;
}
.box ul li img{
display: block;
}
.box ul li .cover{
width: 230px;
height: 360px;
background: url(img/new-bg.png);
position: absolute;
left: 230px;
top:0;
}
.box ul li .cover p{
font-size: 14px;
font-family: "微软雅黑";
text-align: center;
color: #fff;
margin-top: 120px;
}
js:
(function(){
var $li = $(".box ul li");
$li.hover(function(e){
move.call(this,e,true);
},function(e){
move.call(this,e,false);
});
function move(e,bool){
var liTop = $(this).offset().top;
var liLeft = $(this).offset().left;
var liBottom = liTop + $(this).height();
var liRight = liLeft + $(this).width();
//获取鼠标的坐标
var ev = e || window.event;
var pagex = ev.pageX;
var pagey = ev.pageY;
//获取鼠标距离四条边的距离
var jtop = Math.abs(pagey - liTop);
var jbottom = Math.abs(pagey - liBottom);
var jleft = Math.abs(pagex - liLeft);
var jright = Math.abs(pagex - liRight);
console.log(jleft+"--"+jtop)
//获取四个值中的最小值,判断进入的方向
var min = Math.min(jtop,jbottom,jleft,jright);
switch(min){
case jtop:
if(bool){
$(this).find(".cover").css({
top:"-360px",
left:0
}).stop().animate({
top:"0"
});
}else{
$(this).find(".cover").stop().animate({
top:"-360px"
});
}
break;
case jleft:
if(bool){
$(this).find(".cover").css({
left:"-360px",
top:0
}).stop().animate({
left:"0"
});
}else{
$(this).find(".cover").stop().animate({
left:"-360px"
});
}
break;
case jbottom:
if(bool){
$(this).find(".cover").css({
top:"360px",
left:0
}).stop().animate({
top:"0"
});
}else{
$(this).find(".cover").stop().animate({
top:"360px"
});
}
break;
case jright:
if(bool){
$(this).find(".cover").css({
left:"360px",
top:0
}).stop().animate({
left:"0"
});
}else{
$(this).find(".cover").stop().animate({
left:"360px"
});
}
break;
}
}
})();
以上为该效果的全部实现过程!
相关文章推荐
- c#判断鼠标移动的方向调整矩形大小
- jQuery实现的响应鼠标移动方向插件用法示例【附源码下载】
- javascript判断鼠标移动方向
- 判断鼠标移动方向
- 向量叉积应用-判断鼠标移动方向
- js判断鼠标移动方向
- web移动前端页面,jquery判断页面滑动方向
- as3 判断鼠标移动方向
- 解决jQuery 浏览器版本判断BUG
- jQuery javaScript js 判断浏览器的类型、版本的方法
- 提示浮层跟随鼠标移动(js版和jquery版)
- jQuery中浏览器版本判断的一个BUG
- 在嵌入式X系统中Xfbdev鼠标移动方向正好相反的问题。
- 基于jQuery的的一个隔行变色,鼠标移动变色的小插件
- 图片上传生成缩略图,并使用JQuery实现鼠标移动到缩略图显示相应的大图的例子
- jQuery browser msie 判断 浏览器 ie6 bug jQuery中浏览器版本判断的一个BUG,此BUG已影响到jqModal,thickbox等多个jQuery插件的应用
- 读jQuery之七 判断点击了鼠标哪个键的代码
- jQuery javaScript js 判断浏览器的类型、版本的方法
- jquery实现的提示浮层跟随鼠标移动
- 【转】jquery判断浏览器类型、js判断浏览器版本