我在4 - 5年前问过这个问题。现在,格式化它,以便我不会再次被阻止。
我想创建一个带有css但没有javascript的HTML Slider。
这是我的尝试,我该如何改进? https://codepen.io/fearless23/pen/GELXma
HTML
<div class="slides-container">
<div>
<input id="slide1" type="radio" name="login-slide" class="hidden" checked>
<div class="slide">Slide1</div>
<label for="slide1" class="slide-dot"></label>
</div>
<div>
<input id="slide2" type="radio" name="login-slide" class="hidden">
<div class="slide">Slide2 </div>
<label for="slide2" class="slide-dot" style="left: 12.52em;"></label>
</div>
<div>
<input id="slide3" type="radio" name="login-slide" class="hidden">
<div class="slide">Slide3 </div>
<label for="slide3" class="slide-dot" style="left:14.52em;"></label>
</div>
</div>
CSS
*, *:after, *:before {
box-sizing: border-box;
margin: 0;
padding: 0;
}
.slides-container {
position: relative;
display: flex;
width: 100%;
height: 100vh;
}
.slide {
position: absolute;
visibility: hidden;
opacity: 0;
width: 100%;
height: 100%;
padding: 2em 2em 5em;
color: white;
background: black;
}
.slides-container input[type="radio"]:checked + .slide {
visibility: visible;
opacity: 1;
}
.hidden {
position: absolute;
opacity: 0;
hieght: 0;
overflow: hidden;
}
label.slide-dot {
position: absolute;
z-index: 100;
bottom: 2em;
left: 10.52em;
width: 1em;
height: 1em;
background: #fff;
border-radius: 50%;
cursor: pointer;
}
.slides-container input[type="radio"]:checked ~ label {
background: #2ca58d;
}
答案 0 :(得分:1)
您应该真正了解如何使用HTML和CSS。我建议您阅读w3schools.com关于html和css的解释。你想知道的是在这种情况下主要是列表和链接(html-wise)和你可以用边框做的有趣的事情(css-wise)。例如,为了制作CSS圈,David Walsh有一个nice blog-entry。
我还要同意李斯特先生的观点,即你有两点确实是单独的问题。事实上,它们是不同的技术:第一个是HTML / CSS问题,后者是一个javascript问题。
友好的建议:从一开始就不要一切。这会压抑(我知道!)。让自己熟悉HTML的工作方式,尤其是交联页面和内容。一旦掌握了这一点,就可以尝试使用javascript(imho jQuery非常易于访问,如:快速导致结果)。提示:您想尝试jQuery的display: none
CSS属性和div#id.show()
函数。
祝你好运,玩得开心(这就是它应该是什么)!