3

私はmvc3 Webアプリケーションを持っています。その中で私はEFを使用し、データベースから2つのドロップダウンリストを作成しました。

これらのドロップダウンリストから値を選択すると、webgrid 内にそれらを表示する必要があります。これを行うにはどうすればよいですか?

@using (Html.BeginForm()) {
    @Html.ValidationSummary(true)
    <fieldset>
        <legend>Mapping</legend>
        <div class="editor-label">
          @Html.Label("Pricing SecurityID")
        </div>
        <div class="editor-field">
            @Html.DropDownListFor(model => model.ID,
         new SelectList(Model.ID, "Value", "Text"),
            "-- Select category --"
            )
            @Html.ValidationMessageFor(model => model.ID)
        </div>

         <div class="editor-label">
          @Html.Label("CUSIP ID")
        </div>
        <div class="editor-field">
            @Html.DropDownListFor(model => model.ddlId,
         new SelectList(Model.ddlId, "Value", "Text"),
            "-- Select category --"
            )
            @Html.ValidationMessageFor(model => model.ddlId)
        </div>
         <p>
            <input type="submit" value="Mapping" />
        </p>
    </fieldset>
}

ボタンをクリックすると、Mapping呼び出された新しいページMapping.cshtmlに移動し、これらの 2 つの値で webgrid を表示する必要があります。

4

2 に答える 2

3

ViewModelを作成します

public class YourClassViewModel
{

 public IEnumerable<SelectListItem> Securities{ get; set; }
 public int SelectedSecurityId { get; set; }

 public IEnumerable<SelectListItem> CUSIPs{ get; set; }
 public int SelectedCUSIPId { get; set; }

}

Get Action メソッドで、この ViewModel を強く型付けされた View に返します。

public ActionResult GetThat()
{
   YourClassViewModel objVM=new YourClassViewModel();
   objVm.Securities=GetAllSecurities() // Get all securities from your data layer 
   objVm.CUSIPs=GetAllCUSIPs() // Get all CUSIPsfrom your data layer    
   return View(objVm);  
}

そして、強く型付けされている私の見解では、

@model YourClassViewModel     
@using (Html.BeginForm())
{
    Security :
     @Html.DropDownListFor(x => x.SelectedSecurityId ,new SelectList(Model.Securities, "Value", "Text"),"Select one") <br/>

    CUSP:
     @Html.DropDownListFor(x => x.SelectedCUSIPId ,new SelectList(Model.CUSIPs, "Value", "Text"),"Select one") <br/>

  <input type="submit" value="Save" />

}

そして今、私の HttpPost アクション メソッドで、この ViewModel をパラメーターとして受け入れ、そこで Selected 値を取得します

[HttpPost]
public ActionResult GetThat(YourClassViewModel objVM)
{
   // You can access like objVM.SelectedSecurityId
   //Save or whatever you do please...   
}
于 2012-04-12T18:56:38.577 に答える
0

フォームを に投稿しmapping actionresultます。actionresult マッピングでは、パラメーターのドロップダウンを として受け取りますmapping(string ID, string ddID)。これらの値を取得して、ViewData を使用して表示します。より良いアプローチは、グリッド ビューのビューモデルを作成し、マッピング ビューを強く型付けし、必要に応じてグリッドで値を使用することです。

于 2012-04-12T18:45:11.037 に答える