首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >创建子div时,始终将div容器滚动到底部。

创建子div时,始终将div容器滚动到底部。
EN

Stack Overflow用户
提问于 2018-03-01 11:23:15
回答 1查看 94关注 0票数 3

首先,这些是我的推荐信

jQuery Scroll to bottom of page/iframe

jQuery Scroll To bottom of the page

我创建了一些div并将它们放入div容器中。我希望容器始终滚动到底部最新的div。

代码语言:javascript
运行
复制
$(document).ready(function() {

  var container = $("#container");

  var i = 0;

  $("#btn").click(function() {
    i++;

    var div = $("<div></div>");
    div.addClass("d");
    div.html("Container " + i);
    container.append(div);

    container.scrollTop(container.height());
  });
});
代码语言:javascript
运行
复制
body {
  background: white;
}

#container {
  height: 160px;
  width: 120px;
  overflow-y: scroll;
  background: gray;
}

.d {
  height: 30px;
  margin-bottom: 10px;
  background: red;
}
代码语言:javascript
运行
复制
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

<button id="btn">-- Add --</button>

<div id="container">

</div>

如您所见,在我创建超过8个div之前,这是很好的工作方式。然后逻辑将中断,容器不再滚动。

容器应该使用数字i(当前索引)滚动到当前div。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-03-01 11:39:27

因为高度总是固定的,所以考虑使用all的高度滚动子元素,包括它们的上/下边缘。换句话说,如果没有指定的固定高度,则为容器的高度。

更准确地说,您只需要滚动所有子元素的高度减去容器的固定高度,即溢出部分。这就是为什么您的代码部分地工作,因为直到有8个元素的溢出低于容器的固定高度( 8 * 40 = 320 => 320 - 160(fixed height) = 160(overflow) )。

代码语言:javascript
运行
复制
$(document).ready(function() {

  var container = $("#container");

  var i = 0;

  $("#btn").click(function() {
    i++;

    var div = $("<div></div>");
    div.addClass("d");
    div.html("Container " + i);
    container.append(div);

    container.scrollTop(container.find('.d').length * 
                        ($('.d').height() + 10) - 
                        container.height());
  });
});
代码语言:javascript
运行
复制
body {
  background: white;
}

#container {
  height: 160px;
  width: 120px;
  overflow-y: scroll;
  background: gray;
}

.d {
  height: 30px;
  margin-bottom: 10px;
  background: red;
}
代码语言:javascript
运行
复制
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

<button id="btn">-- Add --</button>

<div id="container">

</div>

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49048643

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档