jquery:鼠标滚轮上的动画列表scrollLeft / scrollRight

时间:2015-02-24 09:09:58

标签: javascript jquery scroll mouseevent

当用户使用鼠标滚轮时,我有以下代码向左/向右滚动。事件被很好地绑定,因为我在用户尝试滚动时转到JS代码,但代码从未生效。

<div id="contact_list">
    <ul id="contact_list_ul">
        <li>img1</li>
        <li>img2</li>
        <li>img3</li>
        <li>img4</li>
        <li>img5</li>
        <li>img6</li>
        <li>img7</li>
        <li>img8</li>
        <li>img9</li>
    </ul>
</div>

CSS :(我使用overflow-x,因为我想隐藏滚动条)

#contact_list ul {
   list-style-type: none;
   white-space: nowrap;
   overflow-x: hidden;
}

向右/向左滚动的JS代码:

$("#contact_list_ul").mousewheel(function(event, delta, deltaX, deltaY) {
   var o = '';
   if (deltaY > 0){
     $("#contact_list_ul").animate({scrollRight : '-=200'}, 'slow');
   } else if (deltaY < 0) {
     $("#contact_list_ul").animate({scrollRight :'+=200'}, 'slow');
   }
});

1 个答案:

答案 0 :(得分:2)

我想jquery中没有名为scrollRight的方法,所以我认为应该是scrollLeft

试试这个:

&#13;
&#13;
    $("#contact_list_ul").mousewheel(function(event) {
       var o = '';
       if (event.deltaY > 0){
         $("#contact_list_ul").animate({scrollLeft : '-=200'}, 'slow');
       } else if (event.deltaY < 0) {
         $("#contact_list_ul").animate({scrollLeft :'+=200'}, 'slow');
       }
    });
&#13;
    #contact_list ul {
       list-style-type: none;
       white-space: nowrap;
       overflow-x: hidden;
      width:400px;
      border:solid 1px red;
    }
#contact_list ul li{
width:200px; display:inline-block;
}
&#13;
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script><script src="https://cdnjs.cloudflare.com/ajax/libs/jquery-mousewheel/3.1.12/jquery.mousewheel.min.js"></script>
    <div id="contact_list">
    	<ul id="contact_list_ul">
            <li>img1</li>
            <li>img2</li>
            <li>img3</li>
            <li>img4</li>
            <li>img5</li>
            <li>img6</li>
            <li>img7</li>
            <li>img8</li>
            <li>img9</li>
        </ul>
    </div>
&#13;
&#13;
&#13;