0

2012 年 8 月 14 日 12:05 に更新 自分の状況を説明しようと思います。誰かが正しい方向に向けてくれることを願っています。

私のプロジェクトには、いくつかのテーブルが含まれるフォームがあり、すべてのテーブルはすでにリレーションシップで設定されています。関連するモデルはこちら。

namespace QQAForm.Models
 {
  public class AuditSchedule
    {
    public virtual int AuditScheduleID { get; set; }
    public virtual Nullable<DateTime> audit_completed_date { get; set; }
    public virtual string gl_cmp_key { get; set; }
    public virtual string audit_year { get; set; }
    public virtual string ar_ship_key { get; set; }
    public virtual string ar_ship_name { get; set; }
    public virtual string im_adres_city { get; set; }
    public virtual string im_adres_state { get; set; }
    public virtual string audit_type { get; set; }
    public virtual string audit_no { get; set; }
    public virtual string audit_group { get; set; }
    public virtual string Footage { get; set; }
    public virtual string Rolling3MosFootage { get; set; }
    public virtual string snp_SalesRep8 { get; set; }
    public virtual string epg_sales_rep_accountable { get; set; }
    public virtual string tech_service_rep { get; set; }
    public virtual string audit_done_by { get; set; }
    public virtual Nullable<DateTime> audit_recieved_date { get; set; }
    public virtual string audit_notes { get; set; }
    public virtual string audit_pdf { get; set; }
    public virtual string updated { get; set; }
    public virtual string hidden { get; set; }
    public virtual string en_stats_key { get; set; }
    public virtual string Control_ID { get; set; }
    public virtual Nullable<DateTime> audit_date { get; set; }
    public virtual string contacts_present { get; set; }
    public virtual string audit_furnished_to { get; set; }
    public virtual string spacer_type { get; set; }



   }
}

主な質問:

namespace QQAForm.Models
{
public class MainQuestion
    {
    public virtual int MainQuestionID { get; set; }
    public virtual int SubCategoryID { get; set; }
    public virtual int ReferenceNo { get; set; }
    public virtual int DisplayIndex { get; set; }
    public virtual int SuggestionID { get; set; }
    public virtual string Question { get; set; }

    public virtual SubCategory SubCategory { get; set; }

    public virtual ICollection<Suggestion> suggestions { get; set; }
    public virtual ICollection<DocumentLink> documentLink { get; set; }
    }
 }

子供の質問:

namespace QQAForm.Models
{
public class ChildQuestion
    {
    public virtual int ChildQuestionID { get; set; }
    public virtual int MainQuestionID { get; set; }
    public virtual int ReferenceNo { get; set; }
    public virtual int DisplayIndex { get; set; }
    public virtual string QuestionText { get; set; }
    public virtual string UserEntityType { get; set; }
    public virtual string UserEntityTexts { get; set; }

    public virtual MainQuestion MainQuestion { get; set; }



    }
 }

提案:

namespace QQAForm.Models
{
public class Suggestion
    {
    public virtual int SuggestionID { get; set; }
    public virtual int MainQuestionID { get; set; }
    public virtual int DisplayIndex { get; set; }
    public virtual string ReferenceNo { get; set; }
    public virtual string Suggestions { get; set; }

    public virtual MainQuestion MainQuestion { get; set; }
   }
}

主な答え:

namespace QQAForm.Models
{
public class MainAnswer
    {
    public virtual int MainAnswerID { get; set; }
    public virtual int AuditScheduleID { get; set; }
    public virtual int MainQuestionID { get; set; }
    public virtual string Score { get; set; }
    public virtual string AdditionalNotes { get; set; }

    public virtual AuditSchedule AuditSchedule { get; set; }
    public virtual MainQuestion MainQuestion { get; set; }

    }
 }

サブ質問と回答のチェックボックスを備えた別のテーブルと関係があるあるテーブルからの質問を表示する方法を理解するのに苦労しています。答えは簡単で、Yes、No、N/A です。また、別のテーブルに保持されます。これらすべてをデータテーブルに持っている理由は、編集可能にする必要があるか、領域に追加したい場合です。これがページの外観です。ページの外観を与えるためにテキストを挿入しました。

レイアウト:

<html>
<head>
<title>@ViewBag.Title</title>
<link href="@Url.Content("~/Content/Site.css")" rel="stylesheet" type="text/css" />
<script src="@Url.Content("~/Scripts/jquery-1.5.1.min.js")" type="text/javascript">  </script>
</head>
<body>
<div id="head" class="container">
    @Html.Partial("Header")
 </div>
    <div class="container">
        <div id="main">
            <ul id="breadcrumbs">

            </ul>
            <div id="formTopCol">
              @RenderBody()
              @*@Html.Partial("_Audit")*@  
            </div>
            <div id="formBottomCol">
                    @Html.Action("_SubCategory")

                <div id="formBottomRightCol">
                    @Html.Action("_Forms")
                    @*@RenderBody()*@
                </div>
                <div style="clear:left;"></div>
            </div>
        </div>
    </div>  
    <div class="container">
       @Html.Partial("Footer")
  </div>
 </body>
 </html>

これは次のようになります。 ここに画像の説明を入力

global.asax に、監査レコードを受け入れるための文字列を設定してから、主な質問を引き出しました。質問エリアを選択するサイドメニューがあります。これは、監査スケジュールが本文で、サイド メニューとフォームの質問/回答がパーシャルの Html.Action() であるビューで行われます。

グローバル コード:

            routes.MapRoute(
            "AuditSchedule", // Route name

            "AuditSchedule/Audit/{id}/{section}", // URL with parameters
            new { controller = "AuditSchedule", action = "Audit", id = UrlParameter.Optional, section = UrlParameter.Optional } // Parameter defaults

        );

このためにビューモデルをいじってみましたが、これを機能させることができません。C# コーディングのデータベースに関しては、私は本当に苦手です。

ここに私がコントローラーで取り組んでいるモデルがあります:

namespace QQAForm.ViewModels
{
public class AuditFormEdit
{
    public Models.MainAnswer ScoreInstance { get; set; }

    public List<ScoreCardCheckBoxHelper> ScoreCardCheckBoxHelperList { get; set; }

    public void InitializeScoreCheckBoxHelperList(List<Models.Score> ScoreList)
    {
        if (this.ScoreCardCheckBoxHelperList == null)
            this.ScoreCardCheckBoxHelperList = new List<ScoreCardCheckBoxHelper>();

        if (ScoreList != null
            && this.ScoreInstance != null)
        {
            this.ScoreCardCheckBoxHelperList.Clear();
            ScoreCardCheckBoxHelper scoreCardCheckBoxHelper;
            string scoreTypes =
                string.IsNullOrEmpty(this.ScoreInstance.Score) ?
                string.Empty : this.ScoreInstance.Score;
            foreach (Models.Score scoreType in ScoreList)
            {
                scoreCardCheckBoxHelper = new ScoreCardCheckBoxHelper(scoreType);
                if (scoreTypes.Contains(scoreType.ScoreName))
                    scoreCardCheckBoxHelper.Checked = true;
                this.ScoreCardCheckBoxHelperList.Add(scoreCardCheckBoxHelper);
            }
        }
    }

    public void PopulateCheckBoxsToScores()
    {
        this.ScoreInstance.Score = string.Empty;
        var scoreType = this.ScoreCardCheckBoxHelperList.Where(x => x.Checked)
                              .Select<ScoreCardCheckBoxHelper, string>(x => x.ScoreName)
                              .AsEnumerable();
        this.ScoreInstance.Score = string.Join(", ", scoreType);
    }


    public class ScoreCardCheckBoxHelper : Models.Score
    {
        public bool Checked { get; set; }

        public ScoreCardCheckBoxHelper() : base() { }

        public ScoreCardCheckBoxHelper(Models.Score scoreCard)
        {
            this.ScoreID = scoreCard.ScoreID;
            this.ScoreName = scoreCard.ScoreName;
        }
    }

}
}   

コントローラー部:

        //get
    public ActionResult _Forms(int id)
    {
        AuditFormEdit viewModel = new AuditFormEdit();
        //viewModel.ScoreInstance = _db.MainAnswers.Single(r => r.AuditScheduleID == id);
        viewModel.InitializeScoreCheckBoxHelperList(_db.Scores.ToList());
        return View(viewModel);
    }

    //post
    [HttpPost]
    public ActionResult _Forms(int id, AuditFormEdit viewModel)
    {
        if (ModelState.IsValid)
        {
            viewModel.PopulateCheckBoxsToScores();
            _db.Entry(viewModel.ScoreInstance).State = System.Data.EntityState.Modified;
            _db.SaveChanges();
            return RedirectToAction("/");
        }
        else
        {
            return View(viewModel);
        }
    }

前に述べたように、存在しない ID を要求しているため、ViewModel は機能しません。現在、ビュー モデルには、回答のチェック ボックスを設定するコードしかありません。

ビューコードを追加 2012/08/14 1:00pm

フォームの部分的なビューのほとんどはテストですが、チェック ボックスのコードを補完するスクリプトです

@{ Layout = null; }
@model QQAForm.ViewModels.AuditFormEdit

<table width="698" border="2" cellpadding="2">
<tr>
<td align="center"><b>Section</b><br />1.0</td>
<td><b>Glass edge damage noted. (shells, flakes, sharks teeth)</b>
<br /><br />

@Html.CheckBox("suggestion1") &nbsp;
It was noted that there was a significant amount of glass edge damage observed on the  IG units being produced.  
This glass edge damage may lead to a significantly high glass breakage rate in IG unit handling, in the glazing operation and in service.
[MAJOR CONCERN]
The cause of this glass edge damage should be determined and efforts made to eliminate the damage. 
<br /><br />
@Html.CheckBox("suggestion2") &nbsp;
The glass edge should be smooth and free of chips, flakes, wings, or other damage. Damaged edges may result in stress cracks or premature IG unit failure.
[MAJOR CONCERN]
<br /><br />

<label>Additional Notes:</label><br />
@Html.TextArea("Additional Notes")
<br />
</td>
<td>
        @for (int index = 0; index < Model.ScoreCardCheckBoxHelperList.Count; index++)
        {

            @Html.CheckBoxFor(m => m.ScoreCardCheckBoxHelperList[index].Checked)
            @Html.LabelFor(m => m.ScoreCardCheckBoxHelperList[index], Model.ScoreCardCheckBoxHelperList[index].ScoreName)
            @Html.HiddenFor(m => m.ScoreCardCheckBoxHelperList[index].ScoreID)
            @Html.HiddenFor(m => m.ScoreCardCheckBoxHelperList[index].ScoreName)


        }

 </td>
 </tr>
</table>

サイドメニューの一部は次のとおりです。

@{ Layout = null; }

@model IEnumerable<QQAForm.Models.SubCategory>
<div id="menuCol">
<h3>Audit Sections</h3>
        <ul>
            <li>

      @foreach (var item in Model)
        {

                <div class="sidemenu">
                    @Html.ActionLink(item.SubcategoryName, "Audit", new { section = item.SubCategoryID }, null)
                </div>

        }
            </li>
        </ul>   
</div>

これは本文です:

@model QQAForm.Models.AuditSchedule
@{
ViewBag.Title = "Edit";
Layout = "~/Views/AuditSchedule/_FormLayout.cshtml";
}
<script src="@Url.Content("~/Scripts/jquery.validate.min.js")" type="text/javascript"></script>
<script src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.min.js")"    type="text/javascript"></script>
@using (Html.BeginForm())
{
@Html.ValidationSummary(true)

<fieldset>
<table class="audit-display">
<tr>
<th>ID</th>
<th>Customer</th>
<th>City</th>
<th>State</th>
<th>EPG TSM Rep/NAM</th>
<th>EPG RSM (or NAM's VP)</th>
<th>Tech Rep</th>
<th>Audit Type</th>

</tr>

<tr>
<td>@Html.DisplayFor(m => m.AuditScheduleID)</td>
<td>@Html.DisplayFor(m => m.ar_ship_name)</td>
<td>@Html.DisplayFor(m => m.im_adres_city)</td>
<td>@Html.DisplayFor(m => m.im_adres_state)</td>
<td>@Html.DisplayFor(m => m.epg_sales_rep_accountable)</td>
<td>@Html.DisplayFor(m => m.snp_SalesRep8)</td>
<td>@Html.DisplayFor(m => m.tech_service_rep)</td>
<td>@Html.DisplayFor(m => m.audit_type)</td>


</tr>
 </table>
 <table class="audit-display">
<tr>
<th>Date</th>
<th>Contacts Present</th>
<th>Audit Furnished To</th>
<th>Audit Done By (If not sheduled)</th>
<th>Spacer's Used</th>

</tr>

<tr>
<td>@Html.DisplayFor(m => m.audit_date)</td>
<td>@Html.DisplayFor(m => m.contacts_present)</td>
<td>@Html.DisplayFor(m => m.audit_furnished_to)</td>
<td>@Html.DisplayFor(m => m.audit_done_by)</td>
<td>@Html.DisplayFor(m => m.spacer_type)</td>

</tr>
</table>

</fieldset>
<hr />

}
4

1 に答える 1

0

int id_Forms HttpPost アクションにパラメーターを追加するのはなぜですか? 使わないからいらないでしょ?ビューコードも示していません。

于 2012-08-14T16:18:41.273 に答える