0
大家好所以我最近完成了一個多層次的下拉菜單中的一些代碼 - 大部分的代碼是從以前的開發者,我很熟悉jQuery的本身,以便它一直給我很多麻煩。提交按鈕jQuery的依賴下拉菜單
基本上我需要發生的情況是,當用戶選擇從最後下拉列表中選擇,他們然後點擊一個按鈕,和特定的頁面打開取決於最後一個下拉的信息。目前發生的是他們選擇頁面自動啓動的最後一個選項。我所有嘗試使用代碼的按鈕都是無用的 - 儘管這也是我所知甚少的。
任何幫助,將majorly讚賞
這裏就是我現在有下面的代碼(削減每下拉級條目的數量,但否則是完全相同):
的Jquery:
$(function(){
var $cat = $("#category1"),
$subcat = $("#category2"),
$volt = $("#category3");
$cat.on("change",function(){
var _rel = $(this).val();
$subcat.find("option").attr("style","");
$subcat.val("");
if(!_rel) return $subcat.prop("disabled",true);
$subcat.find("[rel="+_rel+"]").show();
$subcat.prop("disabled",false);
});
$subcat.on("change",function(){
debugger;
var _rel = $(this).val();
$volt.find("option").attr("style","");
$volt.val("");
if(!_rel) return $volt.prop("disabled",true);
$volt.find("[rel="+_rel+"]").show();
$volt.prop("disabled",false);
});
});
我的CSS:
#category2 option{
display:none;
}
#category2 option.label{
display:block;
}
#category3 option{
display:none;
}
#category3 option.label{
display:block;
}
和網頁鱈魚E:
<script src="//code.jquery.com/jquery-1.11.2.min.js"></script>
<form id="formname" name="formname" method="post" action="submitform.asp" >
<table width="50%" border="0" cellspacing="0" cellpadding="5">
<tr>
<td width="41%" align="right" valign="middle">First Dropdown Menu:</td>
<td width="59%" align="left" valign="middle">
<select name="category1" id="category1">
<option value="">Please Select</option>
<option value="Option1">ONE</option>
<option value="Option2">TWO</option>
<option value="Option3">THREE</option>
<option value="Option4">FOUR</option>
</select>
</td>
</tr>
<form id="formname1" name="formname1" method="post" action="submitform.asp" >
<tr>
<td align="right" valign="middle">Second Dropdown Menu:</td>
<td align="left" valign="middle">
<select disabled="disabled" id="category2" name="category2">
<option class="label" value>Please Select</option>
<!-- R -->
<option rel="Option1" value="R12">12</option>
<option rel="Option1" value="R24">24</option>
<option rel="Option1" value="R36">36</option>
<option rel="Option1" value="R48">48</option>
<option rel="Option1" value="R80">80</option>
</select>
</td>
</tr>
<form id="formname2" name="formname2" method="post" action="submitform.asp" >
<tr>
<td align="right" valign="middle">Third Dropdown Menu</td>
<td align="left" valign="middle">
<select disabled="disabled" id="category3" name="category3">
<option class="label" value>Please Select</option>
<!-- R -->
<option rel="R12" value="http://www.yourwebsite.com">R12V1</option>
<option rel="R24" value="http://www.yourwebsite1.com">R24V1</option>
<option rel="R36" value="http://www.yourwebsite2.com">R36V1</option>
<option rel="R48" value="http://www.yourwebsite3.com">R48V1</option>
</select>
</td>
</tr>
<script type="text/javascript">
var urlmenu = document.getElementById('category3');
urlmenu.onsubmit = function() {
window.open(this.options[ this.selectedIndex ].value);
};
</script>
</table>
</form>
</html>
嘿感謝您的回答!雖然我遇到了一些問題。該按鈕將出現,並且下拉菜單仍然有效,但該按鈕保持灰顯並且不可點擊。如果我更改頁面上的腳本SRC到新的您提供的()那麼一切都完全停止工作,沒有下拉等等。有什麼明顯的我做錯了? – Rob
@Rob我的代碼的工作方式是按鈕是灰色,直到你選擇所有3個下拉菜單中的值(我可以幫助改變這一點,如果你喜歡)。如果你明白這一點,那麼當你包含jQuery 2.1.1腳本並打開html頁面時,是否會遇到任何控制檯錯誤?在Chrome中,您可以打開控制檯打開F12 –
該按鈕呈灰色狀態,直到選定值爲止!即使選擇了這個值,它也不會變灰。當我打開控制檯時,它只是一個空白的框。感謝所有的幫助! – Rob