根据选择的下拉列表显示下拉列表
本文关键字:列表显示 下拉列表 选择 | 更新日期: 2023-09-27 18:13:12
在我的控制器中,我的视图中显示了这个类别列表。这是我的应用程序的报告部分。
public SelectList getFields()
{
List<SelectListItem> field = new List<SelectListItem>();
field.Add(new SelectListItem { Text = "Department", Value = "dept" });
field.Add(new SelectListItem { Text = "Referrer", Value = "ref" });
field.Add(new SelectListItem { Text = "Monthly", Value = "cd_key" });
return new SelectList(field, "Value", "Text");
}
public ActionResult HR_RecRep()
{
ViewBag.fields = getFields();
return View();
}
Then in my View:
<script type="text/javascript">
$(document).ready(function () {
//this function will call the views with id=category
$('#fields').change(function () {
//Get the selected value from the dropdownlist
var rep = $(this).val();
//alert(cat);
if (rep.toUpperCase() == "DEPT") {
var text = document.getElementById("dept");
text.style.display = "inline";
$.getJSON('/Reports/getDepartment/', function (data) {
var items = '<option>Select Department...</option>';
$.each(data, function (i, department) {
items += "<option value='" + department.Value + "'>" + department.Text + "</option>";
});
$('#department').html(items);
});
var textValue = document.getElementById("ref");
textValue.style.display = "none";
}
});
});
</script>
<div style="border:0px solid black;width:950px;">
Reports By: @Html.DropDownList("fields", String.Empty)
<span id="dept" style="display:none;"><select id="department" name="department"></select></span>
<span id="ref" style="display:none;"><select id="referrer" name="referrer"></select></span>
在我看来,它成功地显示了Reports By Section的字段。我希望每当我在下拉列表中选择"dept"时,它指的是类别中的部门,它应该显示数据库中所有部门的下拉列表。
这是我的控制器,用于获取部门列表。
public SelectList getDepartment()
{
ViewBag.department = new SelectList(db.rms_departments, "dept_id", "dept_shortname");
return ViewBag;
}
当我尝试使用代码时,当我在报告中选择部门时,它没有显示部门的下拉列表。还有Referrer,当我从下拉菜单中选择它时,它应该会显示数据库中所有员工的下拉菜单。
你能帮我一下吗?非常感谢。也许这和我的剧本有关?
你的问题是你没有从你的动作方法返回JSON,修改你的动作返回JSON:
public ActionResult getDepartment()
{
var departments = db.rms_departments.Select(x=>
new
{
dept_id=dept_id,
dept_shortname=dept_shortname
});
return JSON(departments,JsonRequestBehavior.AllowGet);
}
和脚本修改行:
items += "<option value='" + department.Value + "'>" + department.Text + "</option>";
:
items += "<option value='" + department.dept_id+ "'>" + department.dept_shortname+ "</option>";
我已经知道答案了。我把控制器代码改成这个:
public JsonResult getDepartment()
{
return Json(new SelectList(db.rms_departments, "dept_id", "dept_shortname"), JsonRequestBehavior.AllowGet);
}