仅使用JavaScript(不使用jquery) - 当列表项具有“活动”类时,我希望这样做,使其在容器内居中。
最终结果将是一个轮播,其中“有效”li将在页面上居中,单击另一个li将使其激活,然后它将自动居中(滚动)。我遇到的问题是我似乎无法将其置于中心位置。宽度是页面的100%,因此宽度是动态的。
任何和所有的帮助都会很棒。
HTML:
<div id="container">
<ul id="carousel">
<li>0</li>
<li>1</li>
<li>2</li>
<li>3</li>
<li class="active">4</li>
<li>5</li>
<li>6</li>
<li>7</li>
<li>8</li>
<li>9</li>
</ul>
</div>
的CSS:
html, body {margin:0;padding:0;height:100%;width:100%;}
ul{
position:relative;
width:100%;
height:322px;
margin:0 auto;
padding:0;
overflow-x:hidden;
white-space: nowrap;
}
li{
position:relative;
display:inline-block;
padding:0;
margin-right:20px;
list-style-type:none;
width:200px;
height:200px;
top: 70px;
background-color:#efefef;
border:1px solid #d3d3d3;
border-radius: 12px;
}
li:first-child {
margin-left: 20px;
}
li.active {
top: 20px;
width:300px;
height:300px;
}
的javascript:
var r = document.getElementById('carousel').offsetWidth;
var l = document.getElementById('carousel').scrollWidth;
var m = r / 2;
document.getElementById('carousel').scrollLeft = 0;
document.getElementById('carousel').scrollLeft = m;
答案 0 :(得分:1)
您必须从<li>
<li>
宽度的一半以及之前m
之间的空格