jQuery的鼠标悬停时放大图片的效果制作

效果如下图所示

我们先看完整的代码

 代码如下 复制代码

<!DOCTYPE html>
<html>
<head>
<meta charset="gb2312" />
<title>基于jQuery的鼠标悬停时放大图片的效果制作</title>
<style>
* { margin:0; padding:0; }
img { vertical-align:bottom; border:none; }
body { background:#f0f0f0; height:800px; font-family:Arial;}
ul { list-style:none; }
h1{ font-size:20px; width:680px; margin:3% auto 5px; color:#202020; }
h6{ width:680px; margin:0 auto 20px; font-size:12px; font-weight:normal; color:#333; }
h6 a { color:#09c; }
ul#gallery { width:660px; margin:0 auto 10px; padding-left:20px; border:1px solid #d3d3d3; background:#fff; overflow:hidden; }
ul#gallery li { width:200px; height:200px; float:left; margin:20px 20px 20px 0; display:inline; }
ul#gallery li a.smallimage { background:#333; display:block; width:200px; height:200px; }
#bigimage { position:absolute; display:none; }
#bigimage img { width:400px; height:400px; padding:5px; background:#fff; border:1px solid #e3e3e3; }
</style>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.min.js"></script>
<script>
//<![CDATA[
$(function(){ 
 
    var x = 22;
 var y = 20;
  
 $("a.smallimage").hover(function(e){
  $("body").append('<p id="bigimage"><img src="'+ this.rel + '" alt="" /></p>');
        $(this).find('img').stop().fadeTo('slow',0.5);  
  widthJudge(e);
     $("#bigimage").fadeIn('fast');
 },function(){
     $(this).find('img').stop().fadeTo('slow',1);
  $("#bigimage").remove();
    }); 
 
 $("a.smallimage").mousemove(function(e){
  widthJudge(e);
 }); 
 
    function widthJudge(e){
  var marginRight = document.documentElement.clientWidth - e.pageX;
  var imageWidth = $("#bigimage").width();
  if(marginRight < imageWidth)
  {
      x = imageWidth + 22;
   $("#bigimage").css({top:(e.pageY - y ) + 'px',left:(e.pageX - x ) + 'px'}); 
  }else{
      x = 22;
      $("#bigimage").css({top:(e.pageY - y ) + 'px',left:(e.pageX + x ) + 'px'});
        }; 
 }
});
//]]>
</script>
</head>

<body>
<h1>基于jQuery的鼠标悬停时放大图片的效果演示</h1>

<ul id="gallery">
  <li><a href="/" class="smallimage" rel="images/001_big.jpg"><img src="images/001_small.jpg" alt="" /></a></li>
  <li><a href="/" class="smallimage" rel="images/002_big.jpg"><img src="images/002_small.jpg" alt="" /></a></li>
  <li><a href="/" class="smallimage" rel="images/003_big.jpg"><img src="images/003_small.jpg" alt="" /></a></li>
</ul>
</body>
</html>

下面我来给大家一步不解析这个实例

HTML结构部分:

先编写一个无序列表的结构,a标签中的img标签用来存放小图片,a标签添加一个rel属性,用来存放大图片的路径。

 代码如下 复制代码

<UL id=gallery>
 <LI><A class=smallimage href="http://stylechen.com/" rel=images/001_big.jpg><IMG alt="" src="images/001_small.jpg"></A></LI>
 
 <LI><A class=smallimage href="http://stylechen.com/" rel=images/002_big.jpg><IMG alt="" src="images/002_small.jpg"></A></LI>
 
 <LI><A class=smallimage href="http://stylechen.com/" rel=images/003_big.jpg><IMG alt="" src="images/003_small.jpg"></A></LI>
</UL>

CSS样式表部分:

bigimage是用jQuery创建的一个p标签的id,用来存放大图片,设置其样式为绝对定位,并先隐藏。给a标签添加一个黑色的背景,是为了给图片变暗的效果做铺垫。就这样,一个简单的相册效果就做好了

 代码如下 复制代码

ul#gallery { list-style:none; width:660px; margin:0 auto 10px; padding-left:20px; border:1px solid #d3d3d3; background:#fff; overflow:hidden; }

ul#gallery li { width:200px; height:200px; float:left; margin:20px 20px 20px 0; }

ul#gallery li a.smallimage { background:#333; /*添加一个黑色的背景为图片变暗的效果做铺垫*/ display:block; width:200px; height:200px; }

#bigimage { position:absolute; display:none; /*大图片的父标签设置相对定位并将显示样式设置为隐藏*/ }

#bigimage img { width:400px; height:400px; padding:5px; background:#fff; border:1px solid #e3e3e3; }

jQuery代码部分:

先声明2个变量x,y用来存放大图片离鼠标的距离。在body中追加一个id为bigimage的p标签,用来存放大图片,大图片的路径就包含在了a标签的rel属性中。当鼠标在小图片悬停的时候,将获取到的鼠标在浏览器中的坐标赋值给大图片绝对定位的坐标,并以淡入的效果显示。之后,再给小图片绑定一个mousemove事件,也就是当鼠标移动的时候,大图片就会跟着鼠标移动了。看以下的代码:

 代码如下 复制代码

<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.min.js" type="text/javascript"></script>
<script type="text/javascript">
//<![CDATA[
$(function(){

 var x = 22;
 var y = 20;

 $("a.smallimage").hover(function(e){ //绑定一个鼠标悬停时事件
 //新建一个p标签来存放大图片,this.rel就是获取到a标签的大图片的路径,然后追加到body中
 $("body").append("<p id="bigimage"><img src="" this.rel "" alt="" /></p>");
  
 //改变小图片的透明度为0.5,结合上面的CSS,看起来就象是图片变暗了
 $(this).find("img").stop().fadeTo("slow",0.5);
  
 //将鼠标的坐标和声明的x,y做运算并赋值给大图片绝对定位的坐标,然后以fadeIn的效果显示
 $("#bigimage").css({top:(e.pageY - y ) "px",left:(e.pageX x ) "px"}).fadeIn("fast");
  
 },function(){ <A href="http://www.sorcerylinux.org/">best australian pokies</A> //鼠标离开后
 
 //将变暗的图片复原
 $(this).find("img").stop().fadeTo("slow",1);
  
 //移除新增的p标签
 $("#bigimage").remove();
 });
 
 $("a.smallimage").mousemove(function(e){ //绑定一个鼠标移动的事件
 
 //将鼠标的坐标和声明的x,y做运算并赋值给大图片绝对定位的坐标,这样大图片就能跟随图片而移动了
 $("#bigimage").css({top:(e.pageY -y ) "px",left:(e.pageX x ) "px"});
 });
});

//]]>
</script>

到这一步,效果已经差不多了,但是正如蓝秋枫同志提到的,效果还并不完美。如果弹出的大图片超过了浏览器的宽度就会出现滚动条,这对于用户体验来说的确很不好。趁周末有时间我又在原来的基础上进行了修改。

先分析下思路,默认情况下,弹出的大图片的位置始终是在当前鼠标指针的右侧,如果当前鼠标指针离浏览器右侧边界的宽度小于弹出的大图片的宽度时,就会出现图片溢出浏览器的现象。那么只要写一个语句判断当前鼠标指针离浏览器右侧的边界的宽度是否小于大图片的宽度,然后再根据这个判断来显示。

有了上面的思路就好办了,为了使代码更简洁,提高复用性,我新增了一个widthJudge函数用于判断宽度

 代码如下 复制代码

function widthJudge(e){
//页面的总宽度减去鼠标当前的X坐标得到右侧边界的宽度
 var marginRight = document.documentElement.clientWidth - e.pageX;

//获取弹出的大图片的宽度
 var imageWidth = $("#bigimage").width();

//如果右侧边界的宽度小于弹出的大图片的宽度
 if(marginRight < imageWidth)
 {
//重新计算变量x的值
  x = imageWidth 22;

//此时大图片的位置应该是当前鼠标指针的宽度减去新的x的值
  $("#bigimage").css({top:(e.pageY - y ) "px",left:(e.pageX - x ) "px"}); 
 }else{ //否则
//仍将x定义为22,这一步千万不能省略,因为之前x的值已经改变
  x = 22;

//如果右侧的宽度值够显示大图片,将仍然按照原来的位置显示
  $("#bigimage").css({top:(e.pageY - y ) "px",left:(e.pageX x ) "px"});
}; 
}

最后再结合上面的代码,完整的jQuery代码部分如下:

 代码如下 复制代码

<script type="text/javascript">
//<![CDATA[
$(function(){ 
 
 var x = 22;
 var y = 20;
  
 $("a.smallimage").hover(function(e){
 $("body").append("<p id="bigimage"><img src="" this.rel "" alt="" /></p>");
 $(this).find("img").stop().fadeTo("slow",0.5);  
  widthJudge(e); //调用宽度判断函数
  $("#bigimage").fadeIn("fast");
 },function(){
  $(this).find("img").stop().fadeTo("slow",1);
  $("#bigimage").remove();
 }); 
 
 $("a.smallimage").mousemove(function(e){
  widthJudge(e); //调用宽度判断函数
 }); 
 
 function widthJudge(e){
  var marginRight = document.documentElement.clientWidth - e.pageX;
  var imageWidth = $("#bigimage").width();
  if(marginRight < imageWidth)
  {
   x = imageWidth 22;
   $("#bigimage").css({top:(e.pageY - y ) "px",left:(e.pageX - x ) "px"}); 
  }else{
   x = 22;
   $("#bigimage").css({top:(e.pageY - y ) "px",left:(e.pageX x ) "px"});
 }; 
 }
});
//]]>
</script>

解决了图片溢出浏览器的问题,这个效果还算不错了。如果你喜欢这个效果

时间: 2024-11-08 18:54:02

jQuery的鼠标悬停时放大图片的效果制作的相关文章

jQuery当鼠标悬停时放大图片的效果实例

这个效果最初源于小敏同志的一个想法,刚开始做的时候只能实现弹出的图片是固定的,不能随鼠标移动,最后加以改善,终于实现了比较理想的效果.今天就把制作该效果的经验与大家一同分享.先看看最终效果演示: HTML结构部分: 先编写一个无序列表的结构,a标签中的img标签用来存放小图片,a标签添加一个rel属性,用来存放大图片的路径. 复制代码 代码如下: <UL id=gallery sizcache="6" sizset="7">  <LI sizcac

jQuery当鼠标悬停时放大图片的效果实例_jquery

这个效果最初源于小敏同志的一个想法,刚开始做的时候只能实现弹出的图片是固定的,不能随鼠标移动,最后加以改善,终于实现了比较理想的效果.今天就把制作该效果的经验与大家一同分享.先看看最终效果演示: HTML结构部分:先编写一个无序列表的结构,a标签中的img标签用来存放小图片,a标签添加一个rel属性,用来存放大图片的路径. 复制代码 代码如下: <UL id=gallery sizcache="6" sizset="7">  <LI sizcach

jquery实现鼠标滑过后动态图片提示效果实例_jquery

本文实例讲述了jquery实现鼠标滑过后动态图片提示效果.分享给大家供大家参考.具体如下: 这里jquery实现的鼠标悬停图片提示效果,把鼠标放在图片上的时候,图片向右上角滑动并缩小,同时提示显示出来,类似幻灯片一样的效果,推荐给大家学习借鉴. 运行效果截图如下: 具体代码如下: <!DOCTYPE html> <head> <title>jQuery图片动态信息显示幻灯效果</title> <style> .galleryContainer {

基于jquery实现鼠标滚轮驱动的图片切换效果_jquery

jQuery可以制作出与Flash媲美的动画效果,这点绝对毋庸置疑,本文将通过实例演示一个基于鼠标滚轮驱动的图片切换效果. 本例实现的效果:鼠标滚轮滚动时图片进行切换. 支持键盘方向键实现图片切换效果. 支持点击图片切换,支持点击当前图片链接. 进度条滑块展示图片图片数量进度.XHTML <div class="demo"> <div id="imageflow"> <div id="loading"><

jQuery实现列表自动循环滚动鼠标悬停时停止滚动_jquery

需要在页面中一个小的区域循环滚动展示新闻(公告.活动.图片等等),并且,鼠标悬停时停止滚动并提示,离开后,继续滚动. 效果图:  上干货 html: 复制代码 代码如下: <div id="news"> <ul> <li><a href="#" title="aaaaaaaaaaaaaaa">aaaaaaaaaaaaaaa</a></li> <li><a h

基于jQuery创建鼠标悬停效果的方法_jquery

本文实例讲述了基于jQuery创建鼠标悬停效果的方法.分享给大家供大家参考.具体实现方法如下: 1. 创建HTML: <ul> <li><a href="/tv"><img src="images/tv_off.gif" class="mainnav"></a></li> </ul> 2. 选择.mainnav的class: $(".mainnav&qu

css实现鼠标悬停时滑出层提示的方法

 本文实例讲述了css实现鼠标悬停时滑出层提示的方法.分享给大家供大家参考.具体分析如下: 这是一个简单的鼠标悬停提示特效,类似于alt标签,不过这一种是用纯CSS实现,扩展性好,而且在提示的层里可以加入图片或其它布局,这个要根据你的需要了.   代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-tran

jQuery实现鼠标悬停背景翻转的黑色导航菜单代码_jquery

本文实例讲述了jQuery实现鼠标悬停背景翻转的黑色导航菜单代码.分享给大家供大家参考.具体如下: 这是一款jQuery实现的鼠标悬停背景翻转的黑色导航菜单菜单,预览效果时左下角会提示错误,而且看不到效果,刷新一下就可以看到效果了:当然,在实际使用中,不会出现这样的问题. 运行效果截图如下: 在线演示地址如下: http://demo.jb51.net/js/2015/jquery-mouse-over-bg-cha-black-nav-menu/ 具体代码如下: <!DOCTYPE html

jQuery实现鼠标悬停显示提示信息窗口的方法_jquery

本文实例讲述了jQuery实现鼠标悬停显示提示信息窗口的方法.分享给大家供大家参考.具体实现方法如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"