Помогите написать слайдер из трёх слайдов

95
12 марта 2022, 06:10

Я новичок в js. Не могу написать слайдер. Если кто знает скажите как исправить код, пробовал гуглить, но ничего не найти кроме готовых слайдеров и однослайдовых вариантов. Задача такая: Есть слайдер из трёх картинок, они должны после нажатия кнопки следовать друг за другом. Я привязал движение к переменной count, но не знаю как грамотно привязать его к каждому слайдеру.

let img = document.getElementsByClassName('img')
let href = ['img/1.png','img/2.png','img/3.png']
let count = 0;
function play() {
    count++
    img[0].src = href[count]
    img[1].src = href[count+1]
    img[2].src = href[count+2]
    if(count >= href.length){
        count=0;
    }
}
function non() {
    setInterval(play, 1000);
}
Answer 1

Bсе изображения находятся друг под другом, все скрыты кроме одного с помощью css (класс show). кнопка по очереди перебрасывает класс show с одного изображения на другое.

// находим кнопку 
const btn = document.querySelector('.btn'); 
// находим все изображения с классом .img 
const images = document.querySelectorAll('.img'); 
// счетчик начинается с 1 т.к. текущее изображение с i = 0 сейчас показано 
let i = 1; 
 
btn.addEventListener('click', () => { 
  // количество всех изображений 
  const imgCount = images.length; 
  if (i == imgCount) { 
    i = 0; 
  } 
  // изображение, которое отображается в данный момент 
  const currentImg = document.querySelector('.show'); 
  // скрыть текущее изображение 
  currentImg.classList.remove('show'); 
  // показать следующее изображение 
  images[i].classList.add('show'); 
  // увеличить счетчик 
  i++; 
})
.parent { 
  position: relative; 
} 
 
.img { 
  position: absolute; 
  top: 0; 
  left: 0; 
  display: none; 
} 
 
.show { 
  display: block; 
  position: relative; 
}
<div class="parent"> 
  <img src="https://via.placeholder.com/150" alt="" class="img show"> 
  <img src="" 
    alt="" class="img"> 
  <img src="" 
    alt="" class="img"> 
</div> 
<button class="btn">next</button>

Answer 2

Обычно слайдер делают по-другому. Картинкам (или конейнеру) меняют стили, иногда создают и удаляют элементы img. Менять src наверное не самое лучшее решение, потому что так вы лишаете себя возможности делать какие-нибудь анимации.

В вашем случае ошибка в том, как вы получаете значения массива href. Если count равен 0, то всё в порядке, но как только он станет больше, индекс count + 2 уже не попадёт в массив href. И в этом случае вы бы хотели (если я правильно вас понял) у третьего элемента получить img[2].src = href[0]. На следующем инкременте count, href[0] -- второе изображение, а третье -- href[1].

Становится ясно, что число которое вы прибавляете к текущему count зависит от номера изображения не так просто. Если немного подумать, то можно сообразить что это остаток от деления на длину массива href. То есть (count + номер изображения) % href.length.

let href = [ 
  '', 
  '', 
  '' 
]; 
 
let img = document.querySelectorAll('img'); 
let count = 0; 
function play() { 
  img[0].src = href[count % href.length] 
  img[1].src = href[(count+1) % href.length] 
  img[2].src = href[(count+2) % href.length] 
 
  count++ 
  if(count >= href.length){ 
      count=0; 
  } 
 
} 
function non() { 
  setInterval(play, 1000); 
} 
 non();
<img> 
<img> 
<img>

Это вам для понимания как делать такие штуки. А если делать слайдер с помощью стилей, то можно сделать проще и красивее.

.slider { 
  width: 32px; 
  height: 32px; 
  overflow: hidden; 
  display: flex; 
} 
 
.slider * { 
  width: 100%; 
  animation: slide-left 4s linear infinite; 
} 
 
@keyframes slide-left { 
  0%, 18% { 
    transform:  translateX(0); 
  } 
  36%, 52% { 
    transform: translateX(-100%); 
  } 
  70%, 88% { 
    transform: translateX(-200%); 
  } 
  100% { 
    transform:  translateX(0); 
  } 
}
<div class="slider"> 
  <img src=""> 
  <img src=""> 
  <img src=""> 
</div>

Можно ещё добавить js'а и вообще хорошо будет.

READ ALSO
Отправить скриншот! html2canvas

Отправить скриншот! html2canvas

Доброго времени суток)

105
Создание всплывающего окна для chrome extension

Создание всплывающего окна для chrome extension

Необходимо при двойном клике получить доступ к DOM вкладки и нарисовать в определённом месте всплывающее окно

80
Как правильно передать props

Как правильно передать props

Мне нужно чтобы по нажатию на карточку с фильмом переходило на страницу где будет больше деталей про этот фильмКак правильно я должен передать...

100
Дсесериализация части объекта как subobject

Дсесериализация части объекта как subobject

Допустим есть некий json объект, и мне не нравится расположение полей в нем:

169