我有两种模式:
public class ProfessorModels
{
public string FullName { get; set; }
public int ID { get; set; }
}
和
public class ClassModels
{
public int ID { get; set; }
public string Professor { get; set; }
public decimal Name { get; set; }
}
在我的视图中,有一个表单可以添加该类:
@model MvcApp.Models.ClassModels
@{
ViewBag.Title = "Create";
}
<h2>Create</h2>
<script src="@Url.Content("~/Scripts/jquery.validate.min.js")" type="text/javascript"></script>
<script src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.min.js")" type="text/javascript"></script>
@using (Html.BeginForm()) {
@Html.ValidationSummary(true)
<fieldset>
<legend>ClassModels</legend>
<div class="editor-label">
@Html.LabelFor(model => model.Name)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Name)
@Html.ValidationMessageFor(model => model.Name)
</div>
<p>
<input type="submit" value="Create" />
</p>
</fieldset>
}
<div>
@Html.ActionLink("Back to List", "Index")
</div>
我想在课堂视图中添加一个下拉菜单,其中列出了所有可用的教授。教授在db中,我可以轻松地从控制器调用db并将所有教授加载到某个列表/数组中。 我需要帮助,如何使用 jQuery 与教授一起填充下拉列表。
答案 0 :(得分:8)
在您的控制器中:
[HttpGet]
public virtual JsonResult LoadInfo()
{
var query = _repository.GetInformation(); //Here you return the data.
return Json(query, JsonRequestBehavior.AllowGet);
}
然后在你看来:
<select id="info"></select>
然后使用jQuery加载下拉列表
function LoadInfo() {
$.getJSON("@Url.Action(MVC.ControllerName.MethodName())", null,
function (data) {
$("#info").empty();
$.each(data, function () {
$("#info").append($("<option />").val(this.Id).text(this.Name));
});
});
}
这假定Id和Name是对象的属性。您可以使用ID和FullName,具体取决于您正在加载的下拉列表。我还使用T4MVC来获取不同的方法名称。
希望这有帮助,
答案 1 :(得分:3)
使用action
方法返回Proffessors列表
public ActionResult GetProfessors()
{
var professorList=repo.GetProfessors(); //get list of professor object
return Json(professorList,JsonRequestBehavior.AllowGet);
}
现在在你的视图中,有一个DropDown
<select id="listProfessors"></select>
使用jQuery ajax将数据加载到文档ready
事件的此元素。在您的视图中添加以下脚本。
<script type="text/javascript">
$(function(){
var items="";
$.getJSON("@Url.Action("GetProfessors","YourControllerName")",function(data){
$.each(data,function(index,item){
items+="<option value='"+item.ID+"'>"+item.FullName+"</option>";
});
$("#listProfessors").html(items);
});
});
</script>
假设您的控制器名称为YourController
,并且您正确地将jQuery加载到此页面中。