Добавление слушателей событий onclick и элементов с использованием javascript

0

Я пытаюсь добавить серию изображений на страницу html, используя javascript и цикл for. Но прослушиватели событий, такие как onclick и onmouseover, не реагируют, когда я тестирую страницу.

function changeText(element)
{   
  var menuItems = ['menu_item1','menu_item2','menu_item3','menu_item4'];
  var galleryImages = ["s1.jpg","s2.jpg","s3.jpg","s4.jpg","s5.jpg","s6.jpg","s7.jpg","s8.jpg","s9.jpg","s10.jpg","s11.jpg","s12.jpg","s13.jpg","s14.jpg","s15.jpg","s16.jpg","s17.jpg","s18.jpg","s19.jpg","s20.jpg"];

  var itemText = document.getElementsByClassName(element);
  var textString ="";           
  if(menuItem == menuItems[3])
  {
    for(var i=0;i<galleryImages.length;i++){
      textString+="<img id='img"+i+"'class='imageGallery'src='galleryImgs/s"+i+".jpg' width='150px' onclick='imageZoom('img"+i+"')'>";  
    }
    itemText[0].innerHTML = 'This is now menu_item4 text Left side';
    itemText[1].innerHTML = textString 
  }
  return;   
}

function imageZoom(img)
{
  var image = document.getElementById(img);
  image.style.width = "400px";
}       
  • 1
    Вы получаете сообщение об ошибке в консоли javascript?
  • 0
    Я подозреваю, что если вы проверите консоль, то увидите ошибку типа «imageZoom не определен».
Теги:

1 ответ

2
Лучший ответ

Это ваши персонажи.

This--

onclick='imageZoom('img"+i+"')'

Становится This--

onclick='imageZoom('img1234')'

Парсер HTML sees--

onclick='imageZoom(' some junk

Поэтому просто измените символы кавычек для экранированных двойных кавычек (\").

onclick=\"imageZoom('img"+i+"')\"
  • 0
    +1 отличный ответ.
  • 0
    Спасибо друг, Это сработало хорошо ~!

Ещё вопросы

Сообщество Overcoder
Наверх
Меню