【发布时间】:2019-05-03 12:45:09
【问题描述】:
我在div 中有一个项目列表,而外部div 有一个固定的高度。所以项目溢出但隐藏在外部div 中。我想滚动外部div,直到列表中的最后一项可见。我已经成功了一半。我滚动了外部 div 直到最后一个列表项。
这是我到目前为止所做的:
$(document).ready(function() {
$m = $('.marq');
$q = $('.qbox');
var mh = $m.height();
var qh = $q.height();
var currscr = 0;
scroll();
function scroll() {
var xpx = mh - qh;
if (mh > qh) {
currscr = xpx;
setInterval(function() {
autoscroll();
}, 50);
} else {
console.log("too few items");
}
}
function autoscroll() {
if (currscr > 0) {
var ch = $m.css('top').replace('px', '');
$m.css('top', (ch - 1) + 'px');
--currscr;
}
}
});
.qbox {
height: 90vh;
width: 80vw;
box-sizing: border-box;
overflow: hidden;
}
.marq {
position: relative;
box-sizing: border-box;
}
.item {
background: #4CAF50;
color: white;
box-sizing: border-box;
padding: 5px;
margin-bottom: 8px;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div class="qbox">
<div class="marq">
<div class="item">Item 1</div>
<div class="item">Item 2</div>
<div class="item">Item 3</div>
<div class="item">Item 4</div>
<div class="item">Item 5</div>
<div class="item">Item 6</div>
<div class="item">Item 7</div>
<div class="item">Item 8</div>
<div class="item">Item 9</div>
<div class="item">Item 10</div>
<div class="item">Item 11</div>
<div class="item">Item 12</div>
<div class="item">Item 13</div>
<div class="item">Item 14</div>
<div class="item">Item 15</div>
</div>
</div>
它在到达最后一项时停止。我希望它在延迟一段时间后滚动回第一项。然后在延迟一段时间后滚动到底部。并无限重复。
注意:速度要一致,列表中的项目数不应该影响滚动速度。这适用于滚动,从上到下和从下到上。滚动动画应该更像线性。
有什么帮助吗?
【问题讨论】:
标签: javascript jquery html css loops