马上加入IBC程序猿 各种源码随意下,各种教程随便看! 注册 每日签到 加入编程讨论群

C#教程 ASP.NET教程 C#视频教程程序源码享受不尽 C#技术求助 ASP.NET技术求助

【源码下载】 社群合作 申请版主 程序开发 【远程协助】 每天乐一乐 每日签到 【承接外包项目】 面试-葵花宝典下载

官方一群:

官方二群:

jQuery实现图片预览鼠标放上去以后预览

  [复制链接]
查看4940 | 回复0 | 2013-1-7 17:19:51 | 显示全部楼层 |阅读模式
效果大家以前可能已经见过了,现在主要结合jQuery说明一下实现原理。

html显示原始图片

[HTML] 纯文本查看 复制代码
<a href="../images/4.jpg" class="preview" title="疯狂滑雪">
<img src="../images/4s.jpg" /></a>  
<a href="../images/photo_1.jpg" class="preview" title="奥运吉祥物">
<img width="100" height="75" src="../images/photo_1_small.gif"/></a>


以下是jQuery实现图片预览的主要过程。
hover()事件


[JavaScript] 纯文本查看 复制代码
xOffset = 10;
yOffset = 30;
$("a.preview").hover(function(e){
    this.t = this.title;
    this.title = "";	
    var c = (this.t != "") ? "<br/>" + this.t : "";
    $("body").append("<p id='preview'><img src='"
        + this.href +"' alt='Image preview' />"+ c +"</p>");
    $("#preview")
       .css("top",(e.pageY - xOffset) + "px")
       .css("left",(e.pageX + yOffset) + "px")
       .fadeIn("fast");

    },function(){
        this.title = this.t;
        $("#preview").remove();
    });	


程序中首先找到预览图片,光标移动到某个图片上时,将此图片的预览图片添加到body中,将id命名为preview。preview开始是不可见的,.css()为图片指定了位置,.fadeIn()最终显示预览图片。当光标离开图片时,将添加的预览图片使用remove()方法移除。


使用mousemove()方法移动鼠标时移动预览最后,当鼠标在图片上移动时,应该使用mousemove()方法将图片预览也进行移动。

[JavaScript] 纯文本查看 复制代码
$("a.preview").mousemove(function(e){
    $("#preview")
        .css("top",(e.pageY - xOffset) + "px")
        .css("left",(e.pageX + yOffset) + "px");
});	


jQuery实现图片预览的完整代码

[HTML] 纯文本查看 复制代码
this.imagePreview = function(){
    xOffset = 10;
    yOffset = 30;
    $("a.preview").hover(function(e){
        this.t = this.title;
        this.title = "";
        var c = (this.t != "") ? "<br/>" + this.t : "";
        $("body").append("<p id='preview'><img src='" 
                + this.href +"' alt='Image preview' />"+ c +"</p>");
        $("#preview")
            .css("top",(e.pageY - xOffset) + "px")
            .css("left",(e.pageX + yOffset) + "px")
            .fadeIn("fast");
    },function(){
        this.title = this.t;
        $("#preview").remove();
    });    
    $("a.preview").mousemove(function(e){
        $("#preview")
            .css("top",(e.pageY - xOffset) + "px")
            .css("left",(e.pageX + yOffset) + "px");
    });	
};

C#论坛 www.ibcibc.com IBC编程社区
C#
C#论坛
IBC编程社区
*滑块验证:
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则