我有以下 ActionResult 方法
[HttpGet]
public ActionResult AssignViewers(long? where)
{
try
{
if (where == null)
{
return RedirectToAction("Index", "Groups");
}
else
{
LoadGroups();
ListViewers(where.ToString());
return View();
}
}
catch (Exception ex)
{
throw ex;
}
}
ListViewers是一个 JsonResult 方法,
[HttpGet]
public JsonResult Listviewers(string where)
{
try
{
var data = new AssignUserViewModel();
if (where != null)
{
long? groupid = Convert.ToInt64(where);
AssignUserViewModel objassignuser = ..
...
data = objassignuser;
}
return Json(data, JsonRequestBehavior.AllowGet);
}
catch (Exception ex)
{
throw ex;
}
}
所以我试图在AssignViewers视图初始加载以及它的下拉值更改时绑定这个AssignUserViewModel模型属性
@model Project.ViewModels.AssignUserViewModel
@{
}
<div class="col-lg-12">
<form class="form-horizontal" role="form">
<div class="form-group">
<label class="col-md-1 control-label">Group Name</label>
<div class="col-md-11">
@Html.DropDownListFor(m => m.groupID, new SelectList(ViewBag.Groups, "value", "name"), "Select the group", new { @class = "form-control" , id = "groupvalue"})
</div>
</div>
<div class="form-group">
<label class="col-md-1 control-label">Viewers</label>
<div class="col-md-11">
<select name="country" class="multi-select" multiple="" id="assign_item">
@if (Model != null)
{
var viewers = Model.Viewerlist;
foreach (var viewers in assignedviewers)
{
<option value="@viewers .UserId" selected>@viewers .UserFName @viewers .UserLName</option>
}
}
</select>
</div>
</div>
</form>
<script type="text/javascript">
$(document).ready(function () {
multiselctpopulatefun();
});
$(function () {
$('#groupvalue').change(function () {
$("#assign_item option").remove();
$("#assign_item").multiSelect('refresh');
$.ajax({
url: '@Url.Action("Listviewers", "Groups")',
type: 'GET',
data: { where: $('#groupvalue').val() },
dataType: 'json',
contentType: 'application/json',
success: function (data)
{
multiselctpopulatefun();
}
});
});
});
function multiselctpopulatefun() {
$('#assign_item').multiSelect({
...
});
}
</script>
看法
尽管值在控制器中加载,但这不是绑定模型属性值