5

Result というモデルがあります。これには、student_id、marks、status、remarks などの 4 つのフィールドがあるとします。
これで、生徒のリストが表示されるビューができました。各生徒の前に、試験の点数を入力するためのボタンがあります。ボタンをクリックすると、ポップアップが開き、student_id、マークの 2 つのフィールドと、「合格」と「不合格」の 2 つのボタンがあります。

失敗ボタンをクリックすると、コメントを入力するための別のポップアップが表示されます。
ここで私の質問は、2 番目のポップアップで最初のポップアップの値を保持するにはどうすればよいかということです。2 番目のポップアップの「送信」ボタンをクリックすると、すべての詳細が保存されます。

2 番目のポップアップで隠しフィールドを使用してこれを行う方法を知っています。これを行う他の方法はありますか?

モデル クラスは次の とおり
です。

生徒一覧表示

@{  
List<User> Student = (List<User>)ViewData["Student"];  
}
    <table id="table_id">
      <tr>
        <th class="dbtc">S.No.</th>
           <th class="dbtc">Student Name)</th>
           <th style="width: 110px">Operate</th>
       </tr>

                @foreach (User usr in Student)
                {
                    int index = Student.IndexOf(usr);
                    <tr>
                        <td class="dbtc">
                            @(Student.ToList().IndexOf(usr) + 1)
                        </td>
                        <td>
                            @Html.ActionLink(usr.FirstName + " " + usr.LastName, "Details", "User", new { id = usr.Id }, null)
                        </td>
                        <td>
                                @Ajax.ActionLink("Examine", "Result", new { id = Model.Id, userId = usr.Id }, new AjaxOptions
                                    {
                                        HttpMethod = "GET",
                                        UpdateTargetId = "divPopup",
                                        InsertionMode = InsertionMode.Replace,
                                        OnSuccess = "openPopup('Examine Content')"
                                    })
                        </td>
                    </tr>

調べるの最初の部分的なビュー

@model ComiValve.Models.Result  
@using (Html.BeginForm("ExamPass", "Student", new { @id = (int)ViewBag.id, userId = (int)ViewData["UserId"] }, FormMethod.Post))
{
    <div id="divExamAdvice"></div>
    <div class="editor-label">
        @Html.DisplayNameFor(model => model.Name)
    </div>
    <div class="editor-field">
        @Html.TextAreaFor(model => model.Marks)
    </div>
    <div class="editor-field">
        @Html.TextAreaFor(model => model.Grade)
    </div>
    <div class="login_submit_div">

        <input type="submit" value="Pass" />
        @Ajax.ActionLink("Fail", "ExamAdvice", new { id = (int)ViewBag.id, userId = (int)ViewData["UserId"] }, new AjaxOptions
        {
            HttpMethod = "GET",
            UpdateTargetId = "divPopup",
            OnSuccess = "openPopup('Exam Advice')"
        })
    </div>
}

リメイクの 2 番目の部分ビュー(ユーザーが [失敗] をクリックすると、このビューが開きます。)

@model ComiValve.Models.ExamContent

@using (Html.BeginForm("ExamFail", "Student", new { id = Model.id }, FormMethod.Post))
{
    <div id="divExamAdvice"></div>
    <div class="editor-label">
        @Html.DisplayNameFor(model => model.Remarks)
    </div>
    <div class="editor-field">
        @Html.TextAreaFor(model => model.Remarks)

    </div>
    <div class="left">
        <input type="submit" value="Confirm Fail" />
    </div>
}

コントローラーのメソッド

    public virtual ActionResult ExamContent(int id, int userId)
            {
                ViewBag.IsApprove = true;
                ViewBag.UserId = userId;
                ViewBag.id = id;
                return PartialView("ExamContent");
            }

public virtual ActionResult ExamAdvice(int id, int userId)
        {
            ViewBag.IsApprove = true;
            if (Request.IsAjaxRequest())
            {
                Result result = new Result();
                result.id = id;
                result.User = db.Users.Find(userId);

                return PartialView("ExamAdvice", result);
            }
            else
            {
                return RedirectToAction("Index");
            }
        }
4

1 に答える 1

1

部分ビュー間でモデルを渡すのはなぜですか。単一のモデルを作成して、両方のビューで使用できます。2 つの異なるテーブルがある場合は、「テーブル」タイプの 2 つの異なる「リスト」を作成します。このような

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.ComponentModel.DataAnnotations;
using System.ComponentModel;
using System.Web.Mvc;

namespace LearningMVCapp.Models
{
    public class Data
    {
        public List<tbl_Dept> lstDepatrment;
        public List<tbl_employees> lstEmployees;
        //other properties
    }
}

隠しフィールドの代わりにセッションを使用することもできます。このリンクhttp://www.dotnet-tricks.com/Tutorial/mvc/906b060113-Controlling-Session-Behavior-in-Asp.Net-MVC4.htmlを参照してください。

于 2013-09-16T12:34:52.413 に答える