jQuery自制提示框tooltip

本文介绍了一种使用jQuery实现自定义提示框(Tooltip)的方法,该方法不仅改善了默认提示的响应速度,还增加了鼠标悬停时显示图片预览的功能。通过简单的HTML结构配合CSS样式及jQuery事件监听,实现了高度定制化的提示效果。

自带的title的提示效果的响应速度是非常缓慢的,使用jQuery自制提示tooltip!

我知道没图你们是不会上车的~

jQuery自制提示tooltip

HTML:

<p><a href="#" title="超链接提示1" class="tooltip">提示1</a></p>
<p><a href="#" title="超链接提示2" class="tooltip">提示2</a></p>
<p><a href="#" title="自带超链接提示1">自带超链接提示1</a></p>
<p><a href="#" title="自带超链接提示2">自带超链接提示2</a></p>

CSS:

    p a{display: block;width:150px;height:50px;line-height:50px;
        background:#FF3366;color:#fff;border-radius: 3px;text-align: center;}
    #tooltip{position:absolute;width:200px;height:50px;line-height:50px;border:1px solid #ccc;text-align: center;box-shadow: 1px 1px 2px #ccc;background:#fff;border-radius:5px;}

JQ:

$(function(){
        var x=10,y=20;//使得鼠标相对于tooltip偏离的距离
        $("a.tooltip").mouseover(function(e){
            this.myTitle=this.title;//获取title,临时存储
            this.title="";//避免和原生提示重复

            var  tooltip="<div id='tooltip'>"+this.myTitle+"</div>";
            $("body").append(tooltip);
            //css()设置样式
            $("#tooltip").css({
                "top":(e.pageY+y)+"px",//e.pageX相对与文档,e.clientX相对于可视区
                "left":(e.pageX+x)+"px",
            }).show("fast");
        }).mouseout(function(){
            this.title=this.myTitle;//重复恢复
            $("#tooltip").remove();//记得要把生成的结点移除掉
        }).mousemove(function(e){
            $("#tooltip").css({
                "left":(e.pageX+x)+"px",
                "top":(e.pageY+y)+"px",
            });
        });
    });

改良版:将上面的tooltip内容加上图片预览!

图片预览tooltip

JQ:

$(function(){
        var x=10,y=20;
        $("a.tooltip").mouseover(function(e){
            this.myTitle=this.title;
            this.title="";
            var imgTitle=this.myTitle?"<br/><span id='tooltipspan'>"+this.myTitle+"</span>":"";
            var tooltip="<div id='tooltip'><img src='"+this.href+"' alt='产品预览图'/>"+imgTitle+"</div>";
            $("body").append(tooltip);
            $("#tooltip").css({
                "top":(e.pageY+y)+"px",
                "left":(e.pageX+x)+"px",
            }).show("fast");
        }).mouseout(function(){
            this.title=this.myTitle;
            $("#tooltip").remove();
        }).mousemove(function(e){
            $("#tooltip").css({
                "top":(e.pageY+y)+"px",
                "left":(e.pageX+x)+"px",
            })
        });
    });
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值