jQuery自制提示框tooltip

自带的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",
            })
        });
    });
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值