javascript добавить событие щелчка для нижележащего элемента - PullRequest
0 голосов
/ 26 сентября 2018

Я изучаю javascript и столкнулся со странным случаем, когда делал пример галереи в MDN.Я решил добавить в этот пример простую функцию, но она не сработала.Моя цель - добавить функцию к ".displayed-img" img.

Я знаю, что проблема в "оверлейном" div.и я могу запустить свою функцию, когда я комментирую эту строку в HTML.Но мне интересно, что будет лучшим подходом, когда у меня есть такой случай, и мне нужно получить доступ к объекту, который находится под другим.Спасибо.

Вот мой код:

var displayedImage = document.querySelector('.displayed-img');
var thumbBar = document.querySelector('.thumb-bar');

var btn = document.querySelector('button');
var overlay = document.querySelector('.overlay');
var imgUrl, currentImgUrl;
/* Looping through images */
for (var i = 0; i < 5; i++) {
  imgUrl = 'https://via.placeholder.com/640x48'+(i+1)+'.jpg';
  var newImage = document.createElement('img');
  newImage.setAttribute('src', imgUrl);
  thumbBar.appendChild(newImage);

  newImage.addEventListener ('click', function(e){
    displayedImage.setAttribute('src', e.target.getAttribute('src'));
  } );

}

displayedImage.addEventListener('click', sayHi);

function sayHi(){
  console.log('hi');
}


btn.onclick = function() {
  if (btn.getAttribute('class')==='dark') {
    overlay.style.backgroundColor = 'rgba(0,0,0,0.5)';
    btn.textContent = 'Light';
    btn.setAttribute('class', 'light');

  } else {
    overlay.style.backgroundColor =  'rgba(0,0,0,0)';
    btn.textContent = 'Darken';
    btn.setAttribute('class', 'dark');
  }

}
body {
  width: 640px;
  margin: 0 auto;
}

.full-img {
  position: relative;
  display: block;
  width: 640px;
  height: 480px;
}

.overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 640px;
  height: 480px;
  background-color: rgba(0, 0, 0, 0);
}

button {
  border: 0;
  background: rgba(150, 150, 150, 0.6);
  text-shadow: 1px 1px 1px white;
  border: 1px solid #999;
  position: absolute;
  cursor: pointer;
  top: 2px;
  left: 2px;
}

.thumb-bar img {
  display: block;
  width: 20%;
  float: left;
  cursor: pointer;
}
<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">

    <title>Image gallery</title>

    <link rel="stylesheet" href="style.css">

  </head>

  <body>
    <h1>Image gallery example</h1>

    <div class="full-img">
      <img class="displayed-img" src="https://via.placeholder.com/640x480">
      <div class="overlay"></div>
      <button class="dark">Darken</button>
    </div>

    <div class="thumb-bar">


    </div>
    <script src="main.js"></script>
  </body>
</html>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...