Слайд-шоу цитат Javascript

#javascript #html #css

#javascript #HTML #css

Вопрос:

Просто возникли трудности с моим слайд-шоу на Javascript:

По какой-то причине, когда я загружаю веб-сайт в Chrome, кажется, что на первом слайде не отображается первая цитата. Оно появляется только тогда, когда я нажимаю стрелки предварительного просмотра / следующего или точки внизу слайд-шоу.

Пожалуйста, кто-нибудь может предоставить решение, позволяющее мне отображать первую цитату, как только я открываю веб-сайт.

введите описание изображения здесь

Код, показанный ниже:

 // JavaScript Document
var slideIndex = 1;
showSlides(slideIndex);

function plusSlides(n) {
  showSlides(slideIndex  = n);
}

function currentSlide(n) {
  showSlides(slideIndex = n);
}

function showSlides(n) {
  var i;
  var slides = document.getElementsByClassName("mySlides");
  var dots = document.getElementsByClassName("dot");
  if (n > slides.length) {
    slideIndex = 1
  }
  if (n < 1) {
    slideIndex = slides.length
  }
  for (i = 0; i < slides.length; i  ) {
    slides[i].style.display = "none";
  }
  for (i = 0; i < dots.length; i  ) {
    dots[i].className = dots[i].className.replace(" active", "");
  }
  slides[slideIndex - 1].style.display = "block";
  dots[slideIndex - 1].className  = " active";
}  
 * {
  box-sizing: border-box
}

body {
  font-family: Verdana, sans-serif;
  margin: 0;
}


/* Slideshow container */

.slideshow-container {
  position: relative;
  background: #f1f1f1f1;
  height: 175px;
}


/* Slides */

.mySlides {
  display: none;
  padding: 80px;
  text-align: center;
}


/* Next amp; previous buttons */

.prev,
.next {
  cursor: pointer;
  position: absolute;
  top: 50%;
  width: auto;
  margin-top: -30px;
  padding: 16px;
  color: #888;
  font-weight: bold;
  font-size: 20px;
  border-radius: 0 3px 3px 0;
  user-select: none;
}


/* Position the "next button" to the right */

.next {
  position: absolute;
  right: 0;
  border-radius: 3px 0 0 3px;
}


/* On hover, add a black background color with a little bit see-through */

.prev:hover,
.next:hover {
  background-color: rgba(0, 0, 0, 0.8);
  color: white;
}


/* The dot/bullet/indicator container */

.dot-container {
  text-align: center;
  padding: 20px;
  background: #ddd;
}


/* The dots/bullets/indicators */

.dot {
  cursor: pointer;
  height: 15px;
  width: 15px;
  margin: 0 2px;
  background-color: #bbb;
  border-radius: 50%;
  display: inline-block;
  transition: background-color 0.6s ease;
}


/* Add a background color to the active dot/circle */

.active,
.dot:hover {
  background-color: #717171;
}


/* Add an italic font style to all quotes */

q {
  font-style: italic;
}


/* Add a blue color to the author */

.author {
  color: cornflowerblue;
}  
 <div class="slideshow-container">

  <div class="mySlides">
    <q>I love you the more in that I believe you had liked me for my own sake and for nothing else</q>
    <p class="author">- John Keats</p>
  </div>

  <div class="mySlides">
    <q>But man is not made for defeat. A man can be destroyed but not defeated.</q>
    <p class="author">- Ernest Hemingway</p>
  </div>

  <div class="mySlides">
    <q>I have not failed. I've just found 10,000 ways that won't work.</q>
    <p class="author">- Thomas A. Edison</p>
  </div>

  <a class="prev" onclick="plusSlides(-1)"></a>
  <a class="next" onclick="plusSlides(1)"></a>

</div>

<div class="dot-container">
  <span class="dot" onclick="currentSlide(1)"></span>
  <span class="dot" onclick="currentSlide(2)"></span>
  <span class="dot" onclick="currentSlide(3)"></span>
</div>  

Комментарии:

1. ваш код отлично работает во фрагменте. если вы нажмете синюю кнопку, будут показаны все слайды. куда на странице вы помещаете свой javascript? в <head>?

2. Спасибо за ответ. Я вижу это, я просто не понимаю, почему это не делается в Dreamweaver. У меня есть ссылка на Javascript в разделе <Head> (<тип сценария=»текст / javascript» src=»js.js «></script>). Основной код для Javascript находится в отдельном файле Javascript.

3. Вам нужно поместить свой javascript в нижней части тега <body>, прямо перед закрывающим тегом </body> . либо это, либо поместите свой код в прослушиватель событий onload.

4. Это сработало. Честная игра, большое вам спасибо.

5. Как вы думаете, я могу поместить 3 цитаты в один слайд вместо одной? Для этого мне нужно создать 3 тега div для каждого слайда?