用鼠标水平滚动ul

时间:2012-05-22 03:53:08

标签: javascript jquery jquery-ui jquery-tools

如何使用鼠标光标水平滚动ul?基本上我想模仿this图片库的底部。我在网上找到了一个javascript方法,但它并不是那么顺利。

2 个答案:

答案 0 :(得分:2)

<div>
    <ul>
        <li></li>
        ...
    </ul>
</div>  

和Javascript:

var $div = $('div');
var $ul = $('ul');

// width of div
var width = $div.width();

// width of ul - width of div
var ulWidth = $ul.width() - width;

$div
    .on('mouseenter', function(e) {
        // get left offset of div on page
        var divLeft = $div.offset().left;

        $(window).on('mousemove', function(e) {
            var left = e.pageX - divLeft;
            // get percent of width the mouse position is at
            var percent = left / width;

            // set margin-left on ul to achieve a 'scroll' effect
            $ul.css('margin-left', -(percent * ulWidth));
        });
    })
    .on('mouseleave', function() {
        // remove mousemove event
        $(window).off('mousemove');
    })
;​

http://jsfiddle.net/aarongloege/gQyz6/

您基本上需要根据视口左侧的鼠标位置百分比来定位ul元素(在我的示例中为div)。

答案 1 :(得分:0)

查看这两个现有的jQuery插件,它们可以完全满足您的需求:

1)http://manos.malihu.gr/jquery-thumbnail-scroller

2)http://www.convergent-evolution.co.uk/resources/jquery-plugins/scrolling-carousel/