#asp.net-mvc #entity-framework #linq
#asp.net-mvc #entity-framework #linq
Вопрос:
Ошибка::
Элемент модели, переданный в словарь, имеет тип ‘System.Коллекции.Generic.List`1[PROJECTAL.Модели.ViewModels.EmpViewModel]’, но для этого словаря требуется элемент модели типа ‘ProjDAL.Модели.ViewModels.EmpViewModel’.
Я работаю над приложением mvc. Для одного представления, которое в основном имеет функциональность для поиска по нескольким параметрам. Я использую тот же вид для метода get и post… Это означает, что я передаю 1 или более параметров в текстовые поля и извлекаю результат с помощью linq и сопоставляю с datatable. После передачи параметров значения поступают на контроллер и извлекают точный результат с помощью linq, но проблема возникает, когда я пытаюсь сопоставить результирующий набор linq с моим представлением.
Вот код для проекта —
Контроллер —
[HttpPost]
public ActionResult EmpSearch([Bind(Include = "employee,EmpID,PAN")] Get_EmpDetails_Result get_EmpDetails_Result)
{
var result = from emp in dbCollections.Employees
join nat in dbCollections.NationalID on emp.EmpID equals nat.EmpID
select new EmpViewModel
{
PAN = nat.pan,
EmpID = emp.EmpID,
employee = emp.Name
};
var searchRes = result
.Where(s => s.PAN.Contains(get_EmpDetails_Result.pan)
|| s.EmpID.Contains(get_EmpDetails_Result.empid)
|| s.employee.Contains(get_EmpDetails_Result.employee));
var modelSys = searchRes.ToList();
return View(modelSys);
}
Вид ::::
@model NewProjDAL.Models.ViewModels.EmpViewModel
@{
ViewBag.Title = "empDetails";
Layout = "~/Views/Shared/_Layout.cshtml";
}
//////////// this part is for the multiple criteria search
@using (Html.BeginForm())
{
@Html.AntiForgeryToken()
<div class="form-horizontal">
@Html.ValidationSummary(true, "", new { @class = "text-danger" })
<div class="form-group">
<label>By EmpID</label>
<div class="col-md-10">
@Html.EditorFor(model => model.GetEmpDetails.FirstOrDefault().empid, new { htmlAttributes = new { @class = "form-control" } })
</div>
</div>
<div class="form-group">
<label>By PAN</label>
<div class="col-md-10">
@Html.EditorFor(model => model.GetEmpDetails.FirstOrDefault().pan, new { htmlAttributes = new { @class = "form-control" } })
</div>
</div>
<div class="form-group">
<label>By Name</label>
<div class="col-md-10">
@Html.EditorFor(model => model.GetEmpDetails.FirstOrDefault().employee, new { htmlAttributes = new { @class = "form-control" } })
</div>
</div>
<div class="form-actions center">
<button type="submit" data-animation="pulse" class="btn btn-lg font-medium-1 btn-outline-teal mb-1 block-multiple-msgs buttonAnimation">
<i class="fa fa-check-square-o"></i> Go
</button>
</div>
</div>
}
//////////////////////////////this part is to fetch the result of the previously mentioned multiple search
@if (Model.EmpDetails.Count != 0)
{
<div class="table-responsive">
<table class="table table-striped table-bordered dom-jQuery-events compact" id="DataTbl">
<thead class="navbar-dark navbar-dark bg-blue-grey white">
<tr>
<th>
employee
</th>
<th>
PAN
</th>
<th>
empid
</th>
</tr>
</thead>
<tbody>
@foreach (var item in Model.GetEmpDetails)
{
<tr>
<td>
@Html.DisplayFor(modelItem => item.employee)
</td>
<td>
@Html.DisplayFor(modelItem => item.PAN)
</td>
<td>
@Html.DisplayFor(modelItem => item.empid)
</td>
</tr>
}
</tbody>
</table>
</div>
}
Ответ №1:
Это точно говорит вам, в чем проблема. Вы настроили представление так, чтобы оно принимало единственную EmpViewModel в качестве модели, но ваш контроллер передает список
Вам необходимо создать модель представления для представления критериев поиска и результатов
public class EmployeeSearchViewModel
{
public string EmpId { get; set; }
public string PAN { get; set; }
public string Employee { get; set; }
public List<EmpViewModel> Employees { get; set; } = new List<EmpViewModel>();
}
затем в вашем методе контроллера:
var modelSys = searchRes.ToList();
var viewModel = new EmployeeSearchViewModel
{
PAN = get_EmpDetails_Result.pan,
EmpId = get_EmpDetails_Result.empid,
Employee = get_EmpDetails_Result.employee
Employees = modelSys
};
return View(viewModel);
В представлении:
@Model EmployeeSearchViewModel
Тогда для отображения ваших параметров не нужно извлекать EmpID, PAN и т.д. Из коллекции, только из модели представления, и вы можете привязать свои повторяющиеся результаты к внутренней коллекции «Employees».