如何滚动到div内的元素?我有一个滚动的div,当我点击它时我想要一个链接它会强制div滚动查看里面的元素。我写了这样的JavasSript:document.getElementById(chr).scrollIntoView(true);但这会在滚动div自己的同时滚动所有页面。如何解决?我想这样说MyContainerDiv.getElementById(chr).scrollIntoView(true);
3 回答
慕田峪7331174
TA贡献1828条经验 获得超13个赞
您需要获取要滚动到视图中的元素的顶部偏移量,相对于其父元素(滚动div容器):
var myElement = document.getElementById('element_within_div');var topPos = myElement.offsetTop;
变量topPos现在设置为滚动div的顶部与您希望可见的元素之间的距离(以像素为单位)。
现在我们告诉div使用scrollTop
以下方式滚动到该位置:
document.getElementById('scrolling_div').scrollTop = topPos;
如果您正在使用原型JS框架,那么您将执行以下相同的操作:
var posArray = $('element_within_div').positionedOffset();$('scrolling_div').scrollTop = posArray[1];
同样,这将滚动div,以便您希望看到的元素正好位于顶部(或者如果不可能,则尽可能向下滚动以使其可见)。
杨魅力
TA贡献1811条经验 获得超6个赞
您必须在要滚动到的DIV中找到元素的位置,并设置scrollTop属性。
divElem.scrollTop = 0;
更新:
向上或向下移动的示例代码
function move_up() { document.getElementById('divElem').scrollTop += 10; } function move_down() { document.getElementById('divElem').scrollTop -= 10; }
添加回答
举报
0/150
提交
取消