【发布时间】:2017-12-18 11:52:08
【问题描述】:
我尝试将超链接添加到我的 Javascript 下拉列表中,但是当我尝试这样做时,下拉列表不起作用。共有三个下拉菜单:
- 州:加利福尼亚州、俄勒冈州)
- 县:加利福尼亚州有蒙特雷、阿莱梅达和俄勒冈州有一个城市,即道格拉斯
- 城市:阿拉米达蒙特里县拥有城市:
例如,如果用户选择:
- 州:加利福尼亚
- 县:蒙特雷
- 城市:萨利纳斯
我希望 Salinas 有一个超链接,以便在选择它时:
- 自动重定向到超链接或
- 有一个按钮可以完成操作。
如何使用以下代码将超链接添加到城市(最终下拉列表):
HTML
<form name="myform" id="myForm">
<select name="optone" id="stateSel" size="1">
<option value="" selected="selected">Select state</option>
</select>
<br>
<br>
<select name="opttwo" id="countySel" size="1">
<option value="" selected="selected">Please select state first</option>
</select>
<br>
<br>
<select name="optthree" id="citySel" size="1">
<option value="" selected="selected">Please select county first</option>
</select>
Javascript
var stateObject = {
"California": {
"Monterey": ["Salinas", "Gonzales"],
"Alameda": ["Berkeley"]
},
"Oregon": {
"Douglas": ["Roseburg", "Winston"],
}
}
window.onload = function () {
var stateSel = document.getElementById("stateSel"),
countySel = document.getElementById("countySel"),
citySel = document.getElementById("citySel");
for (var state in stateObject) {
stateSel.options[stateSel.options.length] = new Option(state, state);
}
stateSel.onchange = function () {
countySel.length = 1; // remove all options bar first
citySel.length = 1; // remove all options bar first
if (this.selectedIndex < 1) {
countySel.options[0].text = "Please select state first"
citySel.options[0].text = "Please select county first"
return; // done
}
countySel.options[0].text = "Please select county"
for (var county in stateObject[this.value]) {
countySel.options[countySel.options.length] = new Option(county, county);
}
if (countySel.options.length==2) {
countySel.selectedIndex=1;
countySel.onchange();
}
}
stateSel.onchange(); // reset in case page is reloaded
countySel.onchange = function () {
citySel.length = 1; // remove all options bar first
if (this.selectedIndex < 1) {
citySel.options[0].text = "Please select county first"
return; // done
}
citySel.options[0].text = "Please select city"
var cities = stateObject[stateSel.value][this.value];
for (var i = 0; i < cities.length; i++) {
citySel.options[citySel.options.length] = new Option(cities[i], cities[i]);
}
if (citySel.options.length==2) {
citySel.selectedIndex=1;
citySel.onchange();
}
}
}
【问题讨论】:
-
在此处查看 espacarello 的答案。这将有助于stackoverflow.com/questions/12287672/…
-
@Daniel Zuzevich 这不是一个单一的下拉菜单。这个问题和我的不同,我已经看过了。我的问题中的下拉项放在 javascript 文件本身中,如我的代码所示。
标签: javascript html hyperlink