I'm building a vanilla JS image gallery. Something super simple. I've gotten so far as to be able to change the main display image on the click of one of the thumbnails below, however it changes to the 4th (and last) image of the thumbnails and remains like that.
I'm attempting to use a data set to store each thumbnail's URL and access it later.
My best guess is that there's something wrong in my for loop over the thumbnail images. I think what's happening is I'm just grabbing the total number of thumbnails (in this case 4) and returning that value. Which is why it keeps getting changed to the 4th image no matter which thumbnail you click.
I'll post a fiddle but here's my code so far:
HTML
<section id="showcase">
<div id="display-area">
<img src="https://source.unsplash.com/wtGWZbiDhGc" id="display-image" alt="unpicked oranges on a tree" />
</div>
<ul id="thumbnails">
<li class="thumbnail">
<img src="https://source.unsplash.com/wtGWZbiDhGc" alt="" class="thumb-img" data-thumbsrc="https://source.unsplash.com/wtGWZbiDhGc"/>
</li>
<li class="thumbnail">
<img src="https://source.unsplash.com/gKR4mOceulU" alt="" class="thumb-img" data-thumbsrc="https://source.unsplash.com/gKR4mOceulU"/>
</li>
<li class="thumbnail">
<img src="https://source.unsplash.com/Jz4QMhLvGgw" alt="" class="thumb-img" data-thumbsrc="https://source.unsplash.com/Jz4QMhLvGgw"/>
</li>
<li class="thumbnail">
<img src="https://source.unsplash.com/I7dpBg-Z5Cc" alt="" class="thumb-img"data-thumbsrc="https://source.unsplash.com/I7dpBg-Z5Cc"/>
</li>
</ul>
</section>
JS
const thumbnail = document.querySelectorAll('.thumbnail');
thumbnail.forEach(function(thumb){
thumb.addEventListener("click", changeImage);
});
// elements
const displayArea = document.querySelector('#display-area');
let displaysrc = document.querySelector('#display-image'); // the display image's img tag
let thumbImg = document.querySelectorAll('.thumb-img'); // all img elements w/ thumb-img class
function changeImage(){
// check current value of display image src
console.log("current display src " + displaysrc.src);
for (var i = 0; i < thumbImg.length; i++){
let thumbsrc = thumbImg[i].dataset.thumbsrc;
displaysrc.setAttribute('src', thumbsrc);
}
// check new value of display image src
console.log("new display src " + displaysrc.src);
};
Fiddle: https://jsfiddle.net/Lutcyp5w/
If you need anymore information, just let me know. Thank you!
You should refer to this
(i.e. the target element) somehow inside your event handler to identify the correct element that was clicked.
Try this
:
let thumbsrc = this.querySelector(".thumb-img").dataset.thumbsrc;