如何创建HTML滑块?

时间:2013-08-24 14:07:05

标签: html css

我在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;
}

1 个答案:

答案 0 :(得分:1)

您应该真正了解如何使用HTML和CSS。我建议您阅读w3schools.com关于htmlcss的解释。你想知道的是在这种情况下主要是列表和链接(html-wise)和你可以用边框做的有趣的事情(css-wise)。例如,为了制作CSS圈,David Walsh有一个nice blog-entry

我还要同意李斯特先生的观点,即你有两点确实是单独的问题。事实上,它们是不同的技术:第一个是HTML / CSS问题,后者是一个javascript问题。

友好的建议:从一开始就不要一切。这会压抑(我知道!)。让自己熟悉HTML的工作方式,尤其是交联页面和内容。一旦掌握了这一点,就可以尝试使用javascript(imho jQuery非常易于访问,如:快速导致结果)。提示:您想尝试jQuery的display: none CSS属性和div#id.show()函数。

祝你好运,玩得开心(这就是它应该是什么)!