微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

javascript – 滚动DropDownlist自定义

我使用这个DropDownList搜索项目,我有一个问题我的问题是如何在键盘中向上和向下滚动这个DropDownList?
JSfiddle

解决方法

编辑:由于我的第一个解决方案在添加更多项目时工作不正常,我调整了一点. Here’s the fiddle

我做了什么:

首先,我检查了storeTarget和#search_results的位置,并将其记录到控制台中以找出导致问题的原因.
(这是你自己可以完成的事情……)
我发现的是,在几个项目之后,storeTargetitem的顶部位置高于#search_results的可见区域.

所以我改变了参数

$("#search_results").scrollTop(storeTarget.offset().top);

滚动比当前位置更远一点,并使其更平滑更改if-clause中的检查:

if(storeTarget.offset().top>220){
       $("#search_results").scrollTop($("#search_results").scrollTop()+40);
       console.log(storeTarget.offset().top);
       console.log($("#search_results").scrollTop());
       }

用户上升时,我没有检查是否有这种情况,这是由你决定的.

here’s a working fiddle based on your code

结束编辑

我做了什么:

当使用键向上或向下移动时,我检查storeTarget的offset().top值是大于还是小于200(你可以根据列表的大小改变它),如果是,我们滚动#的顶部搜索结果
商店顶部目标:

if(storeTarget.offset().top>200){
   $("#search_results").scrollTop(storeTarget.offset().top);
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐