[英]Displaying an image when selecting an option from a drop down list
我正在尝试在选择下拉列表中的选项后更改图像:
function volvoCar()
{
var img = document.getElementById("image");
img.src="volvo.png";
return false;
}
依此类推每辆车。
<img id="image" src="Null_Image.png"/>
<select id="CarList">
<option onclick="nullCar()">No Car</option>
<option onclick="volvoCar()">Volvo</option>
<option onclick="audiCar()">Audi</option></select>
我似乎无法在网上找到任何给我解决方案的东西。 是因为我的措辞笨拙还是因为我试图用 javascript 做的事情是不可能的,我不知道。
不是为选项设置onClick
事件,而是为选择设置onChange
事件。
HTML
<img id="image" src="Null_Image.png" />
<select id="CarList">
<option value="Null_Image.png">No Car</option>
<option value="volvo.png">Volvo</option>
<option value="audi.png">Audi</option>
</select>
JavaScript
function setCar() {
var img = document.getElementById("image");
img.src = this.value;
return false;
}
document.getElementById("CarList").onchange = setCar;
好吧,你做错了几件事。
您的函数名为volvoCar
而您正尝试使用名为VolvoCar
的函数 - JavaScript 区分大小写。
这不是分配事件侦听器的最佳方式。 您将它添加到 HTML 中,这被认为是“混乱的”(请参阅Unobtrusive JavaScript )。 此外,您想附加function
,而不是function
的结果(您通过调用它来执行)。 函数是 JavaScript 中的一等对象。
在这种情况下, onclick
是错误的事件处理程序。 您想使用<select>
元素的onchange
处理程序。
所以:
HTML:
<img id="image" src="Null_Image.png"/>
<select id="CarList">
<option value="Null">No Car</option>
<option value="Volvo">Volvo</option>
<option value="Audi">Audi</option>
</select>
JS:
var changeCarImage = function () {
document.getElementById('image').src = this.options[this.selectedIndex].value + "_Image.png"
}
var carList = document.getElementById('CarList');
carList.addEventListener('change', changeCarImage, false); // Note this has some issues in old browsers (IE).
这可以在这里看到工作!
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.