Я пытаюсь создать приложение, которое позволит преподавателю посещать занятия в веб-приложении.Я получил его для отображения учеников в указанном классе вместе с раскрывающимся списком, в котором указаны возможные варианты посещаемости.Когда инструктор нажимает кнопку «Сохранить посещаемость», возвращаемые значения представляют собой просто список всех выбранных значений, таких как Particip_detail = PRESENT & Particip_detail = PRESENT & Particip_detail = ABSENT & Particip_detail = TARDY & Particip_detail = ABSENT & Particip_detail = PRESENT & Particip_detail = PRESENT & Particip_detail = PRESENT & Particip_detail = UNEX + AB.Для каждого студента выбрано каждое значение, но у меня нет возможности узнать, у кого какой статус.
Вот представление, отображающее студентов.
@model IEnumerable<RLCAttendanceWebAppNoOauth.Models.student_list>
@{
ViewBag.Title = "ClassList";
}
<h2>ClassList</h2>
<p>@ViewBag.attend_date</p>
<p>@ViewBag.year</p>
<p>@ViewBag.term</p>
@using (Html.BeginForm("SaveAttendance", "Schedule", FormMethod.Post))
{
<table class="table">
<tr>
<th>
@Html.DisplayNameFor(model => model.ID)
</th>
<th>
@Html.DisplayNameFor(model => model.LAST_NAME)
</th>
<th>
@Html.DisplayNameFor(model => model.FIRST_NAME)
</th>
<th></th>
</tr>
@foreach (var item in Model)
{
<tr>
<td>
@Html.DisplayFor(modelItem => item.ID)
</td>
<td>
@Html.DisplayFor(modelItem => item.LAST_NAME)
</td>
<td>
@Html.DisplayFor(modelItem => item.FIRST_NAME)
</td>
<td>
<p>
@Html.DropDownList("attend_detail", null, "", new { id = item.ID })
</p>
</td>
</tr>
}
</table>
<input type="submit" value="Save Attendance" />
}
Вот модель дляstudent_list.
using System;
using System.Collections.Generic;
public partial class student_list
{
public string LAST_NAME { get; set; }
public string FIRST_NAME { get; set; }
public Nullable<System.DateTime> CHANGE_DATE { get; set; }
public string ACADEMIC_YEAR { get; set; }
public string ACADEMIC_TERM { get; set; }
public string ACADEMIC_SESSION { get; set; }
public string EVENT_ID { get; set; }
public string SECTION { get; set; }
public string ID { get; set; }
}
Вот код от контроллера, который перечисляет студентов в классе.
public ActionResult ClassList(DateTime Attend_Date)
{
Session["attend_date"] = Attend_Date.ToShortDateString();
sp_rlc_lti_student_list_Result model = new sp_rlc_lti_student_list_Result();
var attend_detail = db.attend_detail
.OrderBy(q => q.CODE_VALUE_KEY)
.ToDictionary(q => q.CODE_VALUE_KEY, q => q.LONG_DESC);
ViewBag.attend_detail = new SelectList(attend_detail, "Key", "Value");
var year = Session["year"].ToString();
var term = Session["term"].ToString();
var event_id = Session["course_id"].ToString();
var section = Session["section"].ToString();
var classListQry = from c in db.student_list
where c.ACADEMIC_YEAR == year
& c.ACADEMIC_TERM == term
& c.EVENT_ID == event_id
& c.SECTION == section
& c.CHANGE_DATE > Attend_Date
select c;
return View(classListQry);
}
Вот код от контроллера, который выполняется при нажатии кнопки сохранения.
public ActionResult SaveAttendance()
{
ViewBag.message = "The attendance for the class was saved for: " + Session["attend_date"].ToString();
return View();
}
Когда нажата кнопка «Сохранить», мне нужно иметь возможность отправить выбранную посещаемость для каждого учащегося обратно в базу данных.Модель student_list включает уникальный идентификатор студента, я просто не нашел способа связать выбранное значение в раскрывающемся списке со студентом, для которого он был выбран.