Я новичок в 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);
}
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>
Обычно слайдер делают по-другому. Картинкам (или конейнеру) меняют стили, иногда создают и удаляют элементы 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'а и вообще хорошо будет.
Виртуальный выделенный сервер (VDS) становится отличным выбором
Необходимо при двойном клике получить доступ к DOM вкладки и нарисовать в определённом месте всплывающее окно
Мне нужно чтобы по нажатию на карточку с фильмом переходило на страницу где будет больше деталей про этот фильмКак правильно я должен передать...
Допустим есть некий json объект, и мне не нравится расположение полей в нем: