JQuery控制图片由中心点逐渐放大效果

有的时候我们需要做一个当鼠标放置在图片上的时候,希望图片逐渐变大,即图片的width和height逐渐变大,但是此时,其left值与top值没有改变,故看似不是从中心点进行缩放的。如下图:

JQuery控制图片由中心点逐渐放大效果

从中心点进行缩放

JQuery控制图片由中心点逐渐放大效果

实现代码如下:

<meta><style>  #p1{ width:600px; height:400px; margin:50px auto; position:relative;  text-align: center; padding-left:50px;}  #p1 img{ position:absolute; left:0; top:0; margin: 0 auto;}  </style><p>  	@@##@@  </p>  <script></script><script>  	$(function(){  		$(&#39;#p1 img&#39;).mouseenter(function(){  			var wValue=1.5 * $(this).width();  			var hValue=1.5 * $(this).height();		  			$(this).animate({width: wValue,  							height: hValue,  							left:("-"+(0.5 * $(this).width())/2),  							top:("-"+(0.5 * $(this).height())/2)}, 1000);  		}).mouseleave(function(){  			$(this).animate({width: "100",  										 height: "80",  										 left:"0px",  										 top:"0px"}, 1000 );  		});  	});  </script>

/******************************2016年6月26 补充*******************************************************************/

2016年6月26 补充

今天发现,上面的动画,其实还是有一个小问题的。就是当我多次在相应的元素上移入和移除的时候,就会执行多次mouseenter、mouseleave,当然有人会想,这样会有什么问题呢?那么就看下图

JQuery控制图片由中心点逐渐放大效果

也就是当我的鼠标移出来了,还在反复执行mouseenter、mouseleave。为什么会这样呢?因为JS事件队列中有多个等待执行的动画,关于事件队列,我觉得回头有必要好好总结一下。

修改方案

Jquery提供了stop方法,停止所有在指定元素上正在运行的动画,如下图

JQuery控制图片由中心点逐渐放大效果

修改后效果下图

JQuery控制图片由中心点逐渐放大效果

最终JS部分代码如下

<script>  	$(function(){  		$(&#39;#p1 img&#39;).mouseenter(function(){  			var wValue=1.5 * $(this).width();  			var hValue=1.5 * $(this).height();		  			$(this).stop().animate({width: wValue,  							height: hValue,  							left:("-"+(0.5 * $(this).width())/2),  							top:("-"+(0.5 * $(this).height())/2)}, 1000);  		}).mouseleave(function(){  			$(this).stop().animate({width: "100",  										 height: "80",  										 left:"0px",  										 top:"0px"}, 1000 );  		});  	});  </script>

2017年02月28 补充

解决:如果快速移出,移入停留,图片可以无限放大

最终代码如下,效果图见 http://www.php.cn/

$(function(){  	$('.focus_news').mouseenter(function(){  		var imgObj=$(this).find('img');	  		imgObj.stop().css({width: "100%",height: "100%",left:"0px",top:"0px"});	  		var wValue=1.5 * imgObj.width();  		var hValue=1.5 * imgObj.height();  		imgObj.animate({  			width: wValue,  			height: hValue,  			left:("-"+(0.5 * imgObj.width())/2),  			top:("-"+(0.5 * imgObj.height())/2)}, 500);  		$(this).find('.com_news_title').css('color','#F59300');  	}).mouseleave(function(){  		$(this).find('.com_news_title').css('color','#52A2DE');  		$(this).find('img').stop().animate({width: "100%",  									 height: "100%",  									 left:"0px",  									 top:"0px"}, 500 );  	});  });

 以上就是JQuery控制图片由中心点逐渐放大效果的内容,更多相关内容请关注PHP中文网(www.php.cn)!

JQuery控制图片由中心点逐渐放大效果

© 版权声明
THE END
喜欢就支持一下吧
点赞9 分享