jquery click事件,使用next和prev将列表项滚动到div的顶部

标签 jquery scroll click jquery-selectors html-lists

我正在尝试使用单击事件将下一个和上一个列表项滚动到 div 的顶部,当它到达末尾时,它会显示第一个,使其成为圆形。 如果可能的话,还可以使其每隔一分钟自动向下滚动一次。

下面是我从另一篇文章改编而来的示例:

相反,如果一次显示一个,我想显示尽可能多的可以放入 div 的内容。 我知道我需要如何更改 var currli 以检查当前顶部的内容,并更改 nextli 以将下一个 li 滚动到顶部。

非常感谢任何帮助 =]

<a id="scrollup" href="#">up</a>  
<a id="scrolldown" href="#">down</a>  
<div id="news">
   <ul>
      <li>item One</li>
      <li>item Two</li>
      <li>item Three</li>
      <li>item Four</li>
      <li>item Five</li>
      <li>item Six</li>
      <li>item Seven</li>
   </ul>
</div>

这是 jQuery

$(document).ready(function () {


    $('#arrowdown').click(function(event) {
            event.preventDefault();         // cancel click through
            // get current list item
            var currli = $('#news li:visible');
            // get next list item
            var nextli = currli.next();
            // if nextli length is 0, make it equal to first li
            if (nextli.length == 0) {
                nextli = currli.siblings('#news li:first');
            }
            currli.hide();
            nextli.show();
    });
    $('#arrowup').click(function(event) {
            event.preventDefault();         // cancel click through
            // get current list item
            var currli = $('#news li:visible');
            // get next list item
            var prevli = currli.prev();
            // if nextli length is 0, make it equal to first li
            if (prevli.length == 0) {
                prevli = currli.siblings('#news li:last');
            }
            currli.hide();
            prevli.show();
    });
    $('#news li:nth-child(1)').show();

});

这是 jsFiddle 链接: http://jsfiddle.net/bambam007/kyf9e/

最佳答案

你可以简单地这样做:

     $('#scrollup, #scrolldown').click(function(e) {
            e.preventDefault();   
            var id = e.target.id;
        if(id == 'scrollup'){
            $('li:first').appendTo('ul');
        }else{
            $('li:last').prependTo('ul');
        }
    });

关于jquery click事件,使用next和prev将列表项滚动到div的顶部,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11682488/

相关文章:

javascript - jquery msgbox 的任何替代品

Android smoothScrollBy 表现不佳

jquery - iPhone 和 iPad 滚动结束

html - 单击元素后面的按钮

javascript - 单击时将文本 append 到文本区域?

jquery - 单击后更改 Jquery 属性

javascript - jqueryui 对话框无法在 firefox 11 中输入 `select()`

javascript - Bootstrap 模式按钮没有响应

jquery - 如何制作具有固定标题、滚动和列可调整大小的表格

javascript - 卡住背景滚动的 CSS 叠加菜单