Jump to content
Biel.

próxima image

Recommended Posts

Olá pessoal. O link abaixo tem três image e de inicio aparece image1. Quero fazer o seguinte: dar um click na seta e ir para image2, depois dar outro click na seta e ir para image3 . Somente isso . Obrigado!

.

acessa jsbin

Share this post


Link to post
Share on other sites

Imagine que as fotos estão dentro de um container com barra de rolagem oculta
e ao clicar em prev/next o container será movido Xpx pra esquerda ou para a direita.
segue sugestão:
 

<div class="slider">
  <div class="images-container">
    <figure class='active'><img src="https://picsum.photos/400/300?random=1" /></figure>
    <figure><img src="https://picsum.photos/400/300?random=2" /></figure>
    <figure><img src="https://picsum.photos/400/300?random=3" /></figure>
    <figure><img src="https://picsum.photos/400/300?random=4" /></figure>
    <figure><img src="https://picsum.photos/400/300?random=5" /></figure>
  </div>
  <div class="controllers">
    <button id='prev'>&#10094;</button>
    <button id='next'>&#10095;</button>
  </div>
</div>
<div class="log">
  <p></p>
</div>

 

* {
  box-sizing: border-box;
}

.slider {
  overflow-x: hidden;
  position: relative;
}
.slider .images-container {
  display: flex;
  position: relative;
  width: 100%;
  transition: all 0.2s ease;
}

.slider figure {
  display: flex;
  margin: 0;
  min-width: 100%;
  justify-content: center;
}

.slider .controllers {
  position: absolute;
  top: 50%;
  width: 100%;
  display: flex;
  justify-content: space-between;
  transform: translateY(-50%);
}

.log {
  display: flex;
}
.log > p {
  font-family: monospace;
  white-space: pre;
  margin: 12px;
  padding: 12px;
  border-left: thin solid #eee;
}

 

const log = document.querySelector("div.log");
const slider = document.querySelector("div.slider");
const imagesContainer = slider.querySelector(".images-container");
const figuresCollection = [...imagesContainer.children];
let activeFigure;
let activeIndex;
let figureWidth;

const setImagesContainerPosition = () => {
  console.log("activeIndex :>> ", activeIndex);
  imagesContainer.style.transform = `translateX(-${
    activeIndex * activeFigure.offsetWidth
  }px)`;
};

const moveSlider = (direction) => {
  // select active figure
  activeFigure = slider.querySelector("figure.active");

  // detect index of active figure
  const prevIndex = figuresCollection.indexOf(activeFigure);

  activeIndex =
    (direction === "right"
      ? prevIndex + 1
      : prevIndex - 1 + figuresCollection.length) % figuresCollection.length;

  setImagesContainerPosition();

  // remove active from
  activeFigure.classList.remove("active");
  figuresCollection[activeIndex].classList.add("active");

  log.querySelector("p").innerHTML = JSON.stringify(
    { prevIndex, activeIndex },
    null,
    2
  );
};

next.onclick = () => {
  moveSlider("right");
};
prev.onclick = () => {
  moveSlider("left");
};

window.onresize = setImagesContainerPosition;

veja exemplo rodando aqui:
https://codepen.io/washalbano/pen/ExrKGYZ

Share this post


Link to post
Share on other sites
14 horas atrás, washalbano disse:

Imagine que as fotos estão dentro de um container com barra de rolagem oculta
e ao clicar em prev/next o container será movido Xpx pra esquerda ou para a direita.
segue sugestão:
 


<div class="slider">
  <div class="images-container">
    <figure class='active'><img src="https://picsum.photos/400/300?random=1" /></figure>
    <figure><img src="https://picsum.photos/400/300?random=2" /></figure>
    <figure><img src="https://picsum.photos/400/300?random=3" /></figure>
    <figure><img src="https://picsum.photos/400/300?random=4" /></figure>
    <figure><img src="https://picsum.photos/400/300?random=5" /></figure>
  </div>
  <div class="controllers">
    <button id='prev'>&#10094;</button>
    <button id='next'>&#10095;</button>
  </div>
</div>
<div class="log">
  <p></p>
</div>

 


* {
  box-sizing: border-box;
}

.slider {
  overflow-x: hidden;
  position: relative;
}
.slider .images-container {
  display: flex;
  position: relative;
  width: 100%;
  transition: all 0.2s ease;
}

.slider figure {
  display: flex;
  margin: 0;
  min-width: 100%;
  justify-content: center;
}

.slider .controllers {
  position: absolute;
  top: 50%;
  width: 100%;
  display: flex;
  justify-content: space-between;
  transform: translateY(-50%);
}

.log {
  display: flex;
}
.log > p {
  font-family: monospace;
  white-space: pre;
  margin: 12px;
  padding: 12px;
  border-left: thin solid #eee;
}

 


const log = document.querySelector("div.log");
const slider = document.querySelector("div.slider");
const imagesContainer = slider.querySelector(".images-container");
const figuresCollection = [...imagesContainer.children];
let activeFigure;
let activeIndex;
let figureWidth;

const setImagesContainerPosition = () => {
  console.log("activeIndex :>> ", activeIndex);
  imagesContainer.style.transform = `translateX(-${
    activeIndex * activeFigure.offsetWidth
  }px)`;
};

const moveSlider = (direction) => {
  // select active figure
  activeFigure = slider.querySelector("figure.active");

  // detect index of active figure
  const prevIndex = figuresCollection.indexOf(activeFigure);

  activeIndex =
    (direction === "right"
      ? prevIndex + 1
      : prevIndex - 1 + figuresCollection.length) % figuresCollection.length;

  setImagesContainerPosition();

  // remove active from
  activeFigure.classList.remove("active");
  figuresCollection[activeIndex].classList.add("active");

  log.querySelector("p").innerHTML = JSON.stringify(
    { prevIndex, activeIndex },
    null,
    2
  );
};

next.onclick = () => {
  moveSlider("right");
};
prev.onclick = () => {
  moveSlider("left");
};

window.onresize = setImagesContainerPosition;

veja exemplo rodando aqui:
https://codepen.io/washalbano/pen/ExrKGYZ

washalbano, você fez o trabalho completo e funcionou muito bem, obrigado, mas o que quero saber é que código uso para dar um click na seta e ir para image2, depois dar outro click na seta e ir para image3, usando código javascript moda antiga com base no código que postei. 

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • By Biel.
      Olá pessoal. Ao digitar um texto qualquer no input e pressionar submit o valor do atributo href é alterado temporariamente. Como alterar permanentemente no corpo do documento  o valor do atributo href, digitando um nome de link qualquer no campo input e em seguida submit ?
      <!DOCTYPE html> <html> <head> <style> input { width: 100%; font-size: 20px; } textarea { width: 100%; font-size: 16px; height: 200px; } .class88 { margin-top: 50px; padding: 10px; max-width: 100px; } </style> </head> <body> <h2> alterar valor do atributo href</h2> digite um texto qualquer <input type="text" class="class42" value=""> <a id="linkToChange" href="teste5.php" class="class43"></a> <input type="submit" class="class88" value="enviar" onclick="alterarHref()"> <script> function alterarHref() { // pega o valor da class42 var valorDaclass42 = document.querySelector('.class42').value.trim(); // altera o valor do atributo href para o valorDaclass42 sugerido document.querySelector('.class43').setAttribute('href', valorDaclass42); console.log("Href alterado:", valorDaclass42); } </script> </body> </html>  
    • By Biel.
      Olá pessoal. BannerA está funcionando normalmente. Como usar mesmo script para bannerB e bannerC.
      <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Banner Aleatório</title> <style> /* Estilos opcionais para o banner */ #divPai { margin: auto; border: 2px solid red; } #bannerA { width: 240px; height: 480px; overflow: hidden; position: relative; } #bannerA img { width: 100%; height: auto; position: absolute; top: 0; left: 0; transition: 1.5s ease-in; } #bannerA img.active { opacity: 1; } </style> </head> <body> <div id="divPai"> <div id="bannerA" class="bannerA"> <a href="link1"><img src="image1.jpg" alt="Imagem 1"></a> <a href="link2"><img src="image2.jpg" alt="Imagem 2"></a> <a href="link3"><img src="image3.jpg" alt="Imagem 3"></a> </div> <!-- <hr> <div id="bannerB" class="bannerB"> <a href="link4"><img src="image4.jpg" alt="Imagem 4"></a> <a href="link5"><img src="image5.jpg" alt="Imagem 5"></a> <a href="link6"><img src="image6.jpg" alt="Imagem 6"></a> </div> <hr> <div id="bannerC" class="bannerC"> <a href="link7"><img src="image7.jpg" alt="Imagem 7"></a> <a href="link8"><img src="image8.jpg" alt="Imagem 8"></a> <a href="link9"><img src="image9.jpg" alt="Imagem 9"></a> </div> --> </div> <hr> <script> document.addEventListener("DOMContentLoaded", function() { // var banner = document.getElementById("divPai"); // var images = banner.querySelectorAll("img"); var images = document.querySelectorAll("#bannerA img"); // Função para exibir uma imagem aleatória function showRandomImage() { // Escolhe aleatoriamente um índice de imagem var randomIndex = Math.floor(Math.random() * images.length); // Define todas as imagens como ocultas images.forEach(function(img) { img.style.display = "none"; }); // Exibe a imagem aleatória images[randomIndex].style.display = "block"; } // Chama a função inicialmente e define um intervalo para exibir novas imagens a cada 3 segundos showRandomImage(); setInterval(showRandomImage, 1000); // makeSliderKind('.bannerA', 1000); // makeSliderKind('.bannerB', 2000); // makeSliderKind('.bannerC', 3000); }); </script> </body> </html>  
    • By Biel.
      Olá pessoal. O banner abaixo está funcionando e o link acompanha o banner, até aqui tudo ok ! Quero muito fazer uma transição suave entre uma image e outra, colocando as propiedades e valores no css ou diretamente no javascript e nada de propiedades e valores no html através do style . Se possível coloque no código somente o que precisa . Obrigado!
      <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Banner</title> <style> /* Estilos opcionais para o banner */ .banner { width: 240px; height: 480px; overflow: hidden; position: relative; } .banner img { width: 100%; height: auto; position: absolute; top: 0; left: 0; transition: 1.5s ease-in; } .banner img.active { opacity: 1; } </style> </head> <body> <div class="banner" id="banner"> <a href="link1" class="ggg"><img src="image1.jpg" alt="Imagem 1"></a> <a href="link2" class="ggg"><img src="image2.jpg" alt="Imagem 2"></a> <a href="link3" class="ggg"><img src="image3.jpg" alt="Imagem 3"></a> <a href="link4" class="ggg"><img src="image4.jpg" alt="Imagem 4"></a> <a href="link5" class="ggg"><img src="image5.jpg" alt="Imagem 5"></a> </div> <script> document.addEventListener("DOMContentLoaded", function() { var banner = document.getElementById("banner"); var images = banner.querySelectorAll("img"); // Função para exibir uma imagem aleatória function showRandomImage() { // Escolhe aleatoriamente um índice de imagem var randomIndex = Math.floor(Math.random() * images.length); // Define todas as imagens como ocultas images.forEach(function(img) { img.style.display = "none"; }); // Exibe a imagem aleatória images[randomIndex].style.display = "block"; } // Chama a função inicialmente e define um intervalo para exibir novas imagens a cada 3 segundos showRandomImage(); setInterval(showRandomImage, 3000); }); </script> </body> </html>  
       
    • By Biel.
      Olá pessoal. O banner abaixo está funcionando normalmente, mas a transição entre uma imagem e outra está um tanto truculenta. Quero deixar suave. Como resolver isso? Obrigado !
      <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>transition suave entre uma image e outra</title> <style> #banner { width: 240px; height: 480px; overflow: hidden; position: relative; } #bannerGG { width: 100%; height: auto; position: absolute; top: 0; left: 0; opacity: 0; transition: opacity 1s ease-in-out; } /* #tete:active { opacity: 1; } */ </style> </head> <body> <div id="banner"> <img class="bannerGG" src="imagem1.png" alt="Image 1"> <img class="bannerGG" src="imagem2.png" alt="Image 2"> <img class="bannerGG" src="imagem3.png" alt="Image 3"> <img class="bannerGG" src="imagem4.png" alt="Image 4"> <img class="bannerGG" src="imagem5.png" alt="Image 5"> </div> <script> const image = document.querySelectorAll('.bannerGG'); const banner = document.getElementById('banner'); function showRandomImage() { const randomIndex = Math.floor(Math.random() * image.length); const randomImage = image[randomIndex]; const imgElement = document.createElement('img'); imgElement.src = randomImage.src; const linkElement = document.createElement('a'); linkElement.appendChild(imgElement); banner.innerHTML = ''; banner.appendChild(linkElement); } showRandomImage(); setInterval(showRandomImage, 3000); </script> </body> </html>  
    • By Biel.
      Olá pessoal. O banner abaixo está funcionando, mas quero que o link do banner venha da tag a  e não do javascript . Como resolver? 
      <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Mostrar link do banner que está na tag a</title> <style> #banner { width: 240px; height: 480px; overflow: hidden; position: relative; } .banner-img { width: 100%; height: 100%; object-fit: cover; position: absolute; /* opacity: 0; */ transition: opacity 0.5s ease-in-out; } .banner-link { display: block; width: 100%; height: 100%; } </style> </head> <body> <div id="banner"> <a href="link147"><img class="banner-img" src="imagem1.png" alt="Image 1"></a> <a href="link254"><img class="banner-img" src="imagem2.png" alt="Image 2"></a> <a href="link350"><img class="banner-img" src="imagem3.png" alt="Image 3"></a> <a href="link462"><img class="banner-img" src="imagem4.png" alt="Image 4"></a> <a href="link538"><img class="banner-img" src="imagem5.png" alt="Image 5"></a> </div> <script> const images = document.querySelectorAll('.banner-img'); const banner = document.getElementById('banner'); function showRandomImage() { const randomIndex = Math.floor(Math.random() * images.length); const randomImage = images[randomIndex]; const imgElement = document.createElement('img'); imgElement.src = randomImage.src; imgElement.alt = randomImage.alt; imgElement.classList.add('banner-img'); const linkElement = document.createElement('a'); // linkElement.appendChild(imgElement); linkElement.href = randomImage.href; linkElement.classList.add('banner-link'); linkElement.href = "page" + (randomIndex + 1) + ".html"; // Link para cada imagem linkElement.appendChild(imgElement); banner.innerHTML = ''; banner.appendChild(linkElement); } showRandomImage(); setInterval(showRandomImage, 1000); </script> </body> </html> Resolvido,  Obrigado a todos !
×

Important Information

Ao usar o fórum, você concorda com nossos Terms of Use.