滚动到下一个<文章>
Scroll to next <article>
我正在尝试制作一个JavaScript函数,每当按下向下箭头键时,该函数就会滚动到下一篇文章。我所有的HTML元素都是动态的,都只是没有ID的文章标签。到目前为止,我的脚本可以识别按下的向下键,但从这一点来看,我不知道如何制作一个函数,在不命名文章或类似的东西的情况下向下滚动到下一个文章标签。
document.addEventListener('keydown', function(e){
if(e.keyCode === 40) {
// function to scroll down
}});
我想我需要创建一个变量,它只是HTML页面中的任何文章元素。这可能吗?如果是,我该如何做到这一点,并使函数向下滚动到下一篇文章?提前感谢!
您正在寻找window.scrollTo
函数。您所需要的只是识别下一篇文章的Y偏移量。您可以通过计算该节点的offsetTop
(加上其所有offsetParent
节点)来执行此操作。
另一种解决方案:使用element.scrollIntoView()
或element.scorllIntoViewIfNeeded()
。它也是跨浏览器的,但我更喜欢第一个解决方案,因为它允许你控制动画,即使在最旧的浏览器中也能工作。
相关文章:
- 在<页眉>标签
- 在Shopify中获取博客文章的图片
- 如何更改<svg>标记为<img>用js标记
- Ckeditor-plugin:插入虚假元素add不情愿<p>标签前后
- Ajax文件加载和<输入>文件加载
- 为什么要使用0>javascript中的0
- 检测电话窃听,即:<a href="电话:xxx">在UIWebview上
- 链接所有<a>Meteor
- 在<输入类型=“;文件“/>
- 显示浏览量最高的三篇文章
- Div根据<选择>菜单
- 可以<脚本类型=“;text/javascript”>window.location=“/"</
- 如何首先设置样式<td>表中包含在窗体中的元素
- 通过点击<李>在jQuery中
- 正在检测导航到<a name=“;最新主题”></a>
- 将所选类别循环到ul>李用加载更多按钮
- 如何更改<选择>使用angularJS从控制器获得的值
- 在我的网站上显示最近提交的文章/图片
- 使用下拉列表筛选列表(ul>li)
- 滚动到下一个<文章>