最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - jQuery tool tip on hover - Stack Overflow

programmeradmin2浏览0评论

I am in need of a very lightweight tooltip similar to the 1 found here when you hover a video link under "Popular Videos", a tooltip fades into place, it stays there and you can even select text on it until you move the cursor off it. Facebook and Google+ also have a similar style tool-tip as well as stackoverflow when you hover over a tag. Can someone provide a light weight method of doing this.

I have search and looked at many existing "plugins" they are all somewhat bloated though. Thanks for any help

I am in need of a very lightweight tooltip similar to the 1 found here http://www.history./videos when you hover a video link under "Popular Videos", a tooltip fades into place, it stays there and you can even select text on it until you move the cursor off it. Facebook and Google+ also have a similar style tool-tip as well as stackoverflow when you hover over a tag. Can someone provide a light weight method of doing this.

I have search and looked at many existing "plugins" they are all somewhat bloated though. Thanks for any help

Share Improve this question edited Jul 9, 2011 at 23:34 JasonDavis asked Jul 9, 2011 at 23:18 JasonDavisJasonDavis 49k107 gold badges326 silver badges559 bronze badges 2
  • how e i am not seeing tooltips in chrome, is it showing up for you in chrome – kobe Commented Jul 9, 2011 at 23:22
  • Hi, I am using chrome, are you going to almost the bottom of the page under "Popular Videos" heading? – JasonDavis Commented Jul 9, 2011 at 23:32
Add a ment  | 

1 Answer 1

Reset to default 9

Here's a pretty simple way you could acplish this:

var timeout;

function hide() {
    timeout = setTimeout(function () {
        $("#tooltip").hide('fast');
    }, 500);
};

$("#tip").mouseover(function () {
    clearTimeout(timeout);
    $("#tooltip").stop().show('fast');
}).mouseout(hide);

$("#tooltip").mouseover(function () {
    clearTimeout(timeout);
}).mouseout(hide);

Where #tip is the element you want to mouseover to make the tooltip appear, and #tooltip is the actual tooltip element.

Here's an example: http://jsfiddle/pvyhY/


If you wanted to wrap this in a jQuery plugin:

(function($) {
    $.fn.tooltip = function(tooltipEl) {
        var $tooltipEl = $(tooltipEl);
        return this.each(function() {
            var $this = $(this);            
            var hide = function () {
                var timeout = setTimeout(function () {
                    $tooltipEl.hide();
                }, 500);

                $this.data("tooltip.timeout", timeout);
            };

            /* Bind an event handler to 'hover' (mouseover/mouseout): */
            $this.hover(function () {
                clearTimeout($this.data("tooltip.timeout"));
                $tooltipEl.show();
            }, hide);

            /* If the user is hovering over the tooltip div, cancel the timeout: */
            $tooltipEl.hover(function () {
                clearTimeout($this.data("tooltip.timeout"));
            }, hide);            
        });
    };
})(jQuery);

Usage:

$(document).ready(function() {
    $("#tip").tooltip("#tooltip");
});

Add more functionality and you'll eventually end up with the excellent qTip plugin, which I remend taking a look at as well.

发布评论

评论列表(0)

  1. 暂无评论