Cześć,
jestem tu nowy, więc jeśli popełniłem jakie faux pas to przepraszam, jednak nigdzie nie mogłem odnaleźć odpowiedniej(działającej) porady. Napisałem slider i chciałbym dodać do zdjęć animacje przejścia(zarówno do automatu, jak również do "strzałek"), jednak przerosło to moje umiejętności. W związku z tym chciałbym prosić Was o pomoc, a oto mój kod:
HTML
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<link rel="stylesheet" href="style.css">
</head>
<body>
<main>
<div id="slider">
<div id="box">
<img src="" name="img" class="img">
</div>
<div class="arrowPrev">
<span></span>
</div>
<div class="arrowNext">
<span></span>
</div>
</div>
</main>
<script src="slider.js"></script>
</body>
</html>
CSS
body {
margin: 0;
padding: 0;
}
#slider {
position: relative;
margin: 20px auto;
width: 650px;
height: 450px;
border: 10px solid #fff;
box-shadow: 0 0 5px 2px #ccc;
}
.img {
position: absolute;
width: 100%;
height: 100%;
}
.arrowNext {
right: 0;
}
.arrowPrev {
left: 0;
}
.arrowNext,
.arrowPrev {
position: absolute;
top: 45%;
list-style: none;
width: 60px;
height: 60px;
background-color: #fff;
border-radius: 50%;
transition: 0.5s;
}
.arrowNext:hover,
.arrowPrev:hover {
background-color: #0070ff;
}
.arrowNext span,
.arrowPrev span {
position: absolute;
width: 20px;
height: 20px;
border: 4px solid #0077ff;
transition: 0.5s;
}
.arrowNext span:hover,
.arrowPrev span:hover {
border-color: #fff;
}
.arrowNext span {
top: 50%;
right: 20%;
transform: translateY(-50%) rotate(-45deg);
border-left: none;
border-top: none;
transition: 0.5s;
}
.arrowNext:focus span {
right: 25%;
transition: 0.5s;
}
.arrowNext span::before {
content: "";
position: absolute;
width: 38px;
height: 5px;
border-radius: 10%;
background-color: #fff;
transform-origin: right;
transform: rotate(45deg) translate(2px, 25px) scale(0);
transition: 0.5s;
}
.arrowNext:hover span::before {
transform: rotate(45deg) translate(2px, 25px) scale(1);
transition: 0.5s;
}
.arrowPrev span {
top: 50%;
left: 20%;
transform: translateY(-50%) rotate(-45deg);
border-right: none;
border-bottom: none;
transition: 0.5s;
}
.arrowPrev:focus span {
left: 25%;
transition: 0.5s;
}
.arrowPrev span::before {
content: "";
position: absolute;
width: 38px;
height: 5px;
border-radius: 10%;
background-color: #fff;
transform-origin: left;
transform: rotate(45deg) translate(-3px, -2px) scale(0);
transition: 0.5s;
}
.arrowPrev:hover span::before {
transform: rotate(45deg) translate(-3px, -2px) scale(1);
transition: 0.5s;
}
JS
const imgs = ["img/1.jpg", "img/2.jpg", "img/3.jpg", "img/4.jpg"];
const next = document.querySelector(".arrowNext");
const prev = document.querySelector(".arrowPrev");
const time = 5000;
let i = 0;
next.addEventListener("click", function() {
stop();
if (i < imgs.length - 1) {
i++;
} else {
i = 0;
}
document.img.src = imgs[i];
});
prev.addEventListener("click", function() {
stop();
if (i > 0) {
i--;
} else {
i = imgs.length - 1;
}
document.img.src = imgs[i];
});
function stop() {
window.clearTimeout("changeImage", time);
}
function changeImg() {
if (i < imgs.length - 1) {
i++;
} else {
i = 0;
}
document.img.src = imgs[i];
setTimeout("changeImg()", time);
}
window.onload = changeImg;
Chodzi o przejście typu parallaxa pozioma. Coś takiego:https://www.youtube.com/watch?v=iXhS6KFPLY4 tylko w czystym JS. Z góry za pomoc dziękuję i pozdrawiam ;)