0

我正在尝试设置一个在用户滚动时停止工作的功能,是否有与以下功能相反的功能?

 $(window).scroll(function() {
     //while user is not scrolling do this
 });

这是我想在用户滚动时停止工作的功能,因为我有多个使用数据行的实例,我遇到的问题是当一个工具提示开始加载并且用户意外或偶然地滚动了几个时,页面跳转到最后一个加载。

此功能在页面加载中:

var 目标 = $( '[rel~=tooltip]' ),目标 = 假,工具提示 = 假,标题 = 假;

targets.bind( 'mouseenter', function()
{
    target  = $( this );
    tip     = target.attr( 'title' );
    tooltip = $( '<div id="tooltip"></div>' );

    if( !tip || tip == '' )
        return false;

    target.removeAttr( 'title' );
    tooltip.css( 'opacity', 0 )
           .html( tip )
           .appendTo( 'body' );

    var init_tooltip = function()
    {
        if( $( window ).width() < tooltip.outerWidth() * 1.5 )
            tooltip.css( 'max-width', $( window ).width() / 2 );
        else
            tooltip.css( 'max-width', 500 );

        var pos_left = target.offset().left + ( target.outerWidth() / 2 ) - ( tooltip.outerWidth() / 2 ),
            pos_top  = target.offset().top - tooltip.outerHeight() - 20;

        if( pos_left < 0 )
        {
            pos_left = target.offset().left + target.outerWidth() / 2 - 20;
            tooltip.addClass( 'left' );
        }
        else
            tooltip.removeClass( 'left' );

        if( pos_left + tooltip.outerWidth() > $( window ).width() )
        {
            pos_left = target.offset().left - tooltip.outerWidth() + target.outerWidth() / 2 + 20;
            tooltip.addClass( 'right' );
        }
        else
            tooltip.removeClass( 'right' );

        if( pos_top < 0 )
        {
            var pos_top  = target.offset().top + target.outerHeight();
            tooltip.addClass( 'top' );
        }
        else
            tooltip.removeClass( 'top' );

        tooltip.css( { left: pos_left, top: pos_top } )
               .animate( {opacity: 1 }, 50 );
    };

    init_tooltip();
    $( window ).resize( init_tooltip );

    var remove_tooltip = function()
    {
        tooltip.animate( { opacity: 0 }, 50, function()
        {
            $( this ).remove();
        });

        target.attr( 'title', tip );
    };

    target.bind( 'mouseleave', remove_tooltip );
    tooltip.bind( 'click', remove_tooltip );
});

$('.propAvailable').hover(function(){

    if ($(this).attr("title") == "") {
        $(this).siblings("a.TypesOfProperties").click();
    }
});
4

1 回答 1

1
targets.on( 'mouseenter', doStuff);

function doStuff() {
    target  = $( this );
    tip     = target.attr( 'title' );
    tooltip = $( '<div id="tooltip"></div>' );
    ......etc
}

var timer;

$(window).on('scroll', function() {
    clearTimeout(timer);
    targets.off( 'mouseenter', doStuff);
    timer = setTimeout(function() {
        targets.on( 'mouseenter', doStuff);
    },300);
});
于 2013-05-08T16:39:24.823 回答