我有几个下拉值,其值很容易获得,如下所示。
下拉1:
<select id="a">
<option value="1">Bike</option>
<option value="2">Car</option>
<option value="3">Bus</option>
<option value="4">Cycle</option>
<option value="5">Wagon</option>
</select>
下拉2:
<select id="b">
<option value="1">2 wheel</option>
<option value="2">4 wheel</option>
<option value="3">6 wheel</option>
</select>
我需要根据第一个下拉列表中的选定值更改第二个下拉列表值。例如:
我只能选择使用JavaScript。我尝试过如下,但它不起作用。请帮助指出我错过了什么/做错了。
HTML:
<select id="a" onchange="change();">
<option value="1">Bike</option>
<option value="2">Car</option>
<option value="3">Bus</option>
<option value="4">Cycle</option>
<option value="5">Wagon</option>
</select>
<select id="b">
<option value="1">2 wheel</option>
<option value="2">4 wheel</option>
<option value="3">6 wheel</option>
</select>
JS:
function change() {
if (document.getElementById('a').value == '1')
document.getElementById("b").value = '1';
else if (document.getElementById('a').value == '2')
document.getElementById("b").value = '2';
else if (document.getElementById('a').value == '3')
document.getElementById("b").value = '3';
else if (document.getElementById('a').value == '4')
document.getElementById("b").value = '1';
else if (document.getElementById('a').value == '5')
document.getElementById("b").value = '2';
};
编辑:为了更加明确我的需要,我编辑了上面的例子。
答案 0 :(得分:2)
在您解释之后,我会接受这个:
window.onload=function() {
document.getElementById("a").onchange=function() {
document.getElementById("b").value=this.options[this.selectedIndex].getAttribute("data-sync");
}
document.getElementById("a").onchange(); // trigger when loading
}
<select id="a">
<option value="1" data-sync="1">Bike</option>
<option value="2" data-sync="2" selected>Car</option>
<option value="3" data-sync="3">Bus</option>
<option value="4" data-sync="1">Cycle</option>
<option value="5" data-sync="2">Wagon</option>
</select>
<select id="b">
<option value="1">2 wheel</option>
<option value="2">4 wheel</option>
<option value="3">6 wheel</option>
</select>
实际上你的代码也可以运行 - 也许你的浏览器不喜欢函数名change
function change() {
if (document.getElementById('a').value == '1')
document.getElementById("b").value = '1';
else if (document.getElementById('a').value == '2')
document.getElementById("b").value = '2';
else if (document.getElementById('a').value == '3')
document.getElementById("b").value = '3';
else if (document.getElementById('a').value == '4')
document.getElementById("b").value = '1';
else if (document.getElementById('a').value == '5')
document.getElementById("b").value = '2';
};
<select id="a" onchange="change();">
<option value="1">Bike</option>
<option value="2">Car</option>
<option value="3">Bus</option>
<option value="4">Cycle</option>
<option value="5">Wagon</option>
</select>
<select id="b">
<option value="1">2 wheel</option>
<option value="2">4 wheel</option>
<option value="3">6 wheel</option>
</select>