James Featherstone Ответов: 1

Как связать выбранное значение из выпадающего списка с идентификатором строки в таблице?


I am trying to build an application that will allow a teacher to enter class attendance within a web application. I have gotten it to display the students in the specified class along with a drop down list that is populated with the possible attendance choices. When the instructor clicks the save attendance button, the returned values is just a list of all the chosen values like attend_detail=PRESENT&attend_detail=PRESENT&attend_detail=ABSENT&attend_detail=TARDY&attend_detail=ABSENT&attend_detail=PRESENT&attend_detail=PRESENT&attend_detail=UNEX+AB. It has each value selected for each student, but I have no way to know who had which status.

Вот вид, который показывают студенты.
@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 включает в себя уникальный идентификатор студента, я просто не нашел способа связать значение, выбранное в выпадающем списке, с тем студентом, для которого оно было выбрано.

Что я уже пробовал:

Я не совсем уверен, что попробовать в этот момент. Я искал решения в интернете, и либо их там нет, либо я неправильно задаю вопрос.

1 Ответов

Рейтинг:
2

Gerry Schmitz

c# - Return List<T> from view to controller in MVC 3 - переполнение стека[^]

Используйте переключатели. Проще, ИМО, так как у тебя мало вариантов.