我正在尝试使用javascript和for
循环向html页面添加一系列图像。但是,当我测试页面时,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";
}
答案 0 :(得分:2)
这是你的引用字符。
此 -
onclick='imageZoom('img"+i+"')'
成为这个 -
onclick='imageZoom('img1234')'
HTML解析器看到 -
onclick='imageZoom(' some junk
因此,只需更改转义双引号(\"
)的引号字符。
onclick=\"imageZoom('img"+i+"')\"