Я хочу передать user.Id в частичное представление, чтобы заполнить "@ Html .EditorFor (model => model.UserID, new {@Value = id}))" в частичном представлении. Я получаю ноль в этой Частичной модели Представления. Код для родительского представления:
@model KhanewalNews.Models.user
@{
int id = Model.id;
}
@Html.Partial("AssignRoles",null, new ViewDataDictionary { { "id", id } });
@{
ViewBag.Title = "MemberDetails";
Layout = "~/Views/Shared/_DashboardLayout.cshtml";
}
//parent view implementation here
И код для частичного просмотра:
@model KhanewalNews.Models.Role
<script src="~/Scripts/jquery-1.8.2.min.js"></script>
<script src="~/Scripts/jquery.validate.min.js"></script>
<script src="~/Scripts/jquery.validate.unobtrusive.min.js"></script>
@{
int id = (int)this.ViewData["id"];
}
@using (Html.BeginForm())
{
@Html.AntiForgeryToken()
@Html.ValidationSummary(true)
<fieldset>
<div class="editor-label">
@Html.LabelFor(model => model.UserID)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.UserID, new { @Value = id })
@Html.ValidationMessageFor(model => model.UserID)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.role1)
</div>
<div class="editor-field">
@Html.DropDownListFor(m => m.role1, new SelectList(
new List<Object>{
new { value = "add" , text = "add" },
new { value = "update" , text = "update" },
new { value = "delete" , text = "update"},
new { value = "super" , text = "super"}
},
"value",
"text"
))
@Html.ValidationMessageFor(model => model.role1)
</div>
<p>
<input type="submit" value="Create" />
</p>
</fieldset>
}
<div>
@Html.ActionLink("Back to List", "Index")
</div>
. Это создает исключение в частичном представлении, которое " System.NullReferenceException: 'Ссылка на объект не установлена для экземпляра объекта.' " Пожалуйста, сообщите мне, где я ошибаюсь. Контроллер
public ActionResult AssignRoles()
{
return View();
}
[HttpPost]
public ActionResult AssignRoles(Role r)
{
//implementation here
return View();
}
public ActionResult MemberDetails(int id)
{
var userdetail = new user();
var user = db.users.Where(x => x.id == id).FirstOrDefault();
userdetail.username = user.username;
return View(userdetail);
}