我是 jQuery 新手,我正在尝试制作一个表单,该表单将根据用户从下拉选择框中选择的内容显示和隐藏选项。我在这里搜索过,但还没有找到适合我的解决方案。我找到了一个基本上做了我想要的教程,但它似乎只适用于选择框。任何帮助表示赞赏。
这是我正在使用的 HTML 代码。
$(document).ready(function(){
$("#emeorg").change(function(){
switch($(this).val()){
case "add":
$("#test1").slideDown("slow");
$("#changebox select:not(#emeorg, #test1)").slideUp("slow");
break;
case "edit":
$("#test2").slideDown("slow");
$("#changebox select:not(#emeorg, #edithidden)").slideUp("slow");
break;
case "remove":
$("#test3").slideDown("slow");
$("#changebox select:not(#emeorg, #removehidden)").slideUp("slow");
break;
}
});
});
这是我正在使用的 HTML 代码。
<div id="changebox">
<fieldset>
<legend><strong>Emergency Organization Information</strong></legend>
<div id="prompt">Select Action:</div><div id="answer"><select id="emeorg" name="emeorg">
<option value="add">Add New Org</option>
<option value="edit">Edit Existing Org</option>
<option value="remove">Remove Existing Org</option>
</select></div>
<div id="edithidden" style="display:none;">
<div id="prompt">Section to Edit:</div>
<div id="answer">
<select id="test2">
<option>Section to Edit</option>
</select>
</div>
</div>
<div id="removehidden">
<div id="prompt">Section to Remove</div>
<div id="answer">
<select id="test3">
<option>Section to Remove</option>
</select>
</div>
</div>
<div id="prompt">Organization Name:</div><div id="answer"><input type="text" name="companyname" id="companyname" /></div>
<div id="prompt">Organization Phone Number:</div><div id="answer"><input type="text" name="companyname" id="companyname" /></div>
<div id="prompt">Orginization Location:</div><div id="answer"><input type="text" name="companyname" id="companyname" /></div>
<div id="test3"><div id="prompt">Orginization Location Remove:</div><div id="answer"><input type="text" name="companyname" id="companyname" /></div></div>
<div id="prompt"><input type="submit" id="maininfoupdate" value="Update Information" /></div>
</fieldset>
</div>
我只是无法弄清楚为什么 div 不会显示。测试我唯一具有内联样式的是要显示的edithidden:none;。对那个没有影响,但是 removehidden 只显示选择框一秒钟然后它向上滑动。
有任何想法吗?
提前致谢。
编辑
修改后的 jQuery 代码:
$(document).ready(function(){
$("#emeorg").change(function(){
switch($(this).val()){
case "add":
$("#changebox select:not(#emeorg, #test1)").slideUp("slow");
break;
case "edit":
$("#edithidden").slideDown("slow");
$("#changebox select:not(#emeorg, #edithidden)").slideUp("slow");
break;
case "remove":
$("#removehidden").slideDown("slow");
$("#changebox select:not(#emeorg, #removehidden)").slideUp("slow");
break;
}
});
});
修改后的 HTML 代码:
<div id="changebox">
<fieldset>
<legend><strong>Emergency Organization Information</strong></legend>
<div id="prompt">Select Action:</div><div id="answer"><select id="emeorg" name="emeorg">
<option value="add">Add New Org</option>
<option value="edit">Edit Existing Org</option>
<option value="remove">Remove Existing Org</option>
</select></div>
<div id="edithidden" style="display:none;">
<div id="prompt">Section to Edit:</div>
<div id="answer">
<select id="editcontent">
<option>Section to Edit</option>
</select>
</div>
</div>
<div id="removehidden" style="display:none;">
<div id="prompt">Section to Remove</div>
<div id="answer">
<select id="removecontent">
<option>Section to Remove</option>
</select>
</div>
</div>
<div id="prompt">Organization Name:</div><div id="answer"><input type="text" name="companyname" id="companyname" /></div>
<div id="prompt">Organization Phone Number:</div><div id="answer"><input type="text" name="companyname" id="companyname" /></div>
<div id="prompt">Orginization Location:</div><div id="answer"><input type="text" name="companyname" id="companyname" /></div>
<div id="prompt"><input type="submit" id="maininfoupdate" value="Update Information" /></div>
</fieldset>
</div>
现在,当我选择编辑部分时,edithidden 向下滑动,但没有出现选择框。当我将它改回添加时,它不会隐藏编辑滑落的垃圾。我想至少正在取得一些进展。再次感谢您迄今为止的所有帮助。