我通过AJAX请求提取一些JSON内容,但是当我尝试将其附加到嵌套div时它不会滚动 - 滚动条出现但是它处于非活动状态。
<style>
.tbox {
width:440px;
height: 500px;
background-color:white;
border:1px solid #E8E8E8;
border-color:rgba(0,0,0,0.1);
border-radius:5px;
position:relative;
-moz-box-shadow:3px 3px 14px #000;
-webkit-box-shadow:3px 3px 14px #000;
box-shadow:3px 3px 14px #000;
margin:20px 0 0 50px;
overflow: hidden;
}
.tbox .tbox-header {
padding:12px;
border-bottom:1px solid #E8E8E8;
border-bottom-color:rgba(0,0,0,0.1);
width: 100%;
height: auto;
overflow: hidden;
}
h1.ttitle {
font-size:18px;
line-height:18px;
font-weight:bold;
}
.tbox .tbox-body {
width: 100%;
height: auto;
overflow-x:hidden;
overflow-y: scroll;
position: relative;
}
ol {
list-style-type:none;
padding:2px;
}
ol li {
clear:both;
border-bottom:1px solid #E8E8E8;
border-color:rgba(0,0,0,0.1);
margin-bottom:15px;
overflow:hidden;
width:auto;
height:auto;
}
</style>
<div class="tbox">
<div class="tbox-header">
<h1 class="ttitle">My Title</h1>
</div>
<div class="tbox-body">
<ol>
</ol>
</div>
</div>
<script>
$.ajax({
type: "GET",
url: "[my PHP api]",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (data) {
$.each(data, function (i, t) {
$('.tbox-body ol').append(t.content);
});
}
});
</script>
如果我删除了两个嵌套类(.tbox-header
和.tbox-body
)并直接附加到.tbox
它可以正常工作,但是当我尝试将内容附加到嵌套div {{1滚动条处于非活动状态。将.tbox-body
上的overflow-y选项更改为自动或滚动并不能解决问题。
答案 0 :(得分:3)
您遇到的问题是tbox-body
不知道需要滚动的位置。 tbox
设置为500px的固定高度。最简单的解决方案是计算tbox-tbody
的可用高度,并在css中设置它的高度。
作为概念的快速证明,如果您更改.tbox-tbody
:
height:auto;
为:
height:300px;
你应该看到它现在滚动。在tbox-tbody
上设置预定高度后,它也消除了对元素的各种overflow:hidden
的需要。您只需要在overflow
上指定tbox-tbody
属性。