首页 > 语言 > JavaScript > 正文

JQuery鼠标移到小图显示大图效果的方法

2024-05-06 16:22:07
字体:
来源:转载
供稿:网友

这篇文章主要介绍了JQuery鼠标移到小图显示大图效果的方法,涉及jQuery鼠标事件与图形操作技巧,需要的朋友可以参考下

本文实例讲述了JQuery鼠标移到小图显示大图效果的方法。分享给大家供大家参考。具体分析如下:

这里的显示大图功能类似上一篇《JQuery实现超链接鼠标提示效果的方法》,稍微修改一下代码,就可以做出一个图片的提示效果。

参考前面的超链接提示效果的代码,只需要将创建的div元素的代码改为:

 

 
  1. //创建 div 元素 图片提示 
  2. var tooltip = "<div id="tooltip"><img src=""+ this.href +"" alt="预览图"><//div>";  
  3. </div> 

当鼠标滑过图片后,显示就会有大图提示效果。为了使效果更为人性化,还需要为图片增加说明文字,即提示出来的大图片下面出现图片相应的介绍文字。

可以根据超链接的title属性值来获得图片相应的介绍文字,JQuery代码如下:

 

 
  1. this.myTitle = this.title;  
  2. this.title = "";  
  3. var imgTitle = this.myTitle? "<br />" + this.myTitle : ""

然后将它追加到div元素中,代码如下:

 

 
  1. // 创建 div 元素 
  2. var tooltip = "<div id='tooltip'><img src='"this.href +"' alt='产品预览图'/>"+imgTitle+"<//div>";  

在判断this.myTitle是否为""时,使用了三元运算。三元运算结构为:Boolean? 值1 : 值2。它的第1个参数必须为布尔值。当然三元运算也可以用“if(){ }else{ }”代替,例如:

 

 
  1. var imgTitle;  
  2. if (this.myTitle) {  
  3. imgTitle = "<br />" + this.myTitle;  
  4. else {  
  5. imgTitle = "";  

这样,图片提示效果就完成了,当鼠标滑过图片时,图片会出现预览的大图,大图下面还会有介绍文字。

本例完整代码如下:

 

 
  1. <script type="text/javascript"
  2. //<![CDATA[ 
  3. $(function(){ 
  4. var x = 10; 
  5. var y = 20; 
  6. $("a.tooltip").mouseover(function(e){ 
  7. this.myTitle = this.title; 
  8. this.title = "";  
  9. var imgTitle = this.myTitle? "<br/>" + this.myTitle : ""
  10. var tooltip = "<div id='tooltip'><img src='"this.href +"' alt='预览图'/>"+imgTitle+"<//div>"
  11. //创建 div 元素 
  12. $("body").append(tooltip); 
  13. //把它追加到文档中  
  14. $("#tooltip"
  15. .css({ 
  16. "top": (e.pageY+y) + "px"
  17. "left": (e.pageX+x) + "px" 
  18. }).show("fast"); //设置x坐标和y坐标,并且显示 
  19. }).mouseout(function(){ 
  20. this.title = this.myTitle;  
  21. $("#tooltip").remove(); //移除  
  22. }).mousemove(function(e){ 
  23. $("#tooltip"
  24. .css({ 
  25. "top": (e.pageY+y) + "px"
  26. "left": (e.pageX+x) + "px" 
  27. }); 
  28. }); 
  29. }) 
  30. //]]> 
  31. </script> 

希望本文所述对大家的jQuery程序设计有所帮助。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选