1

2つのリストボックス(list1、list2)を含むWebページがあり、アイテムを1つのリストボックスから別のリストボックスに移動したり、元に戻したりできます。送信ボタンをクリックすると、list2のすべてのアイテムの値をhttppostメソッドに戻したいです

私には3つの問題があります:

  1. 選択したリストのプロパティを定義するにはどうすればよいですか?
  2. 最初の空のリスト(list2用)を作成するにはどうすればよいですか?list1にアイテムが入力されていますか?
  3. 送信ボタンがクリックされたときに、list2アイテムのすべてをモデルに戻す方法は?

モデル:

public class TestModel
{
    public List<SelectListItem> OptionList { get; set; }
    public List<SelectListItem> SelectedOptionList { get; set; }
    public string[] SelectedOptions { get; set; }
}

コントローラ:

private TestModel testModel  = new TestModel();

public ActionResult TestPage()
{
    ViewBag.Message = "Test Page";

    testModel.OptionList = new List<SelectListItem>();

    for (int i = 1; i <= 100; i++)
    {
        SelectListItem item = new SelectListItem();
        item.Text = "Option " + i.ToString();
        item.Value = item.Text;

        testModel.OptionList.Add(item);
    }

    return View("TestView", testModel);
}

[HttpPost]
public ActionResult TestPage(TestModel formModel)
{
    testModel.SelectedOptionList = formModel.SelectedOptionList;
    testModel.SelectedOptions = formModel.SelectedOptions;

    //do something
    return RedirectToAction("TestPage");
}

意見:

@model EngineeringDataAnalysisGui.Models.TestModel

@{
    ViewBag.Title = @ViewBag.Message;
}

@section Subtitle
{
    @ViewBag.Message
}

<table width="100%">
@using (Html.BeginForm("TestPage", "RetrieveData", FormMethod.Post))
{
    <tr>
        <td>Event List:</td>
        <td>@Html.ListBox("lstEventSelection", Model.OptionList, new { id = "list1", Multiple = "multiple", Size = 15, style = "width: 100%;" })</td>
    </tr>
    <tr>
        <td></td>
        <td>
            <table style="text-align:center; width: 100%">
                <tr>
                    <td id="buttonCol">
                        <input type="button" id="btnAddAllEvent" title="Add All Events" onclick="moveAllOptions('list1','list2', true)" />
                        <input type="button" id="btnAddEvent" title="Add Selected Events" onclick="moveSelectedOptions('list1','list2', true)" />
                    </td>
                    <td id="buttonCol">
                        <input type="button" id="btnRemoveEvent" title="Remove Selected Events" onclick="moveSelectedOptions('list2','list1', true)" />
                        <input type="button" id="btnRemoveAllEvent" title="Remove All Events" onclick="moveAllOptions('list2','list1', true)" />
                    </td>
                </tr>
            </table>
        </td>
    </tr>
    <tr>
        <td>Selected Event List:</td>
        @*Not sure how to add the listbox*@
        <td>@*Wrong*@@Html.ListBoxFor(x => x.SelectedOptions, Model.SelectedOptionList, new { id = "list2", Multiple = "multiple", Size = 15, style = "width: 100%;" })</td>
    </tr>
    <tr>
        <td><input type="submit" value="submit" /></td>
    </tr>
}
</table>
4

1 に答える 1

11

1)選択したリストのプロパティを定義するにはどうすればよいですか?
@Html.ListBoxFor(x => x.SelectedOptions, new MultiSelectList(Model.SelectedOptionList), new { id = "list2", Multiple = "multiple", Size = 15, style = "width: 100%;" })

2)最初の空のリスト(list2用)を作成するにはどうすればよいですか?list1にアイテムが入力されました。コントローラで空のリストを設定しますtestModel.SelectedOptionList = new List<SelectListItem>();

3)送信ボタンがクリックされたときにすべてのlist2アイテムをモデルに戻す方法
おそらく、送信する前に、list2のすべてのアイテムを(jqueryを使用して)選択されたものとして設定する必要があります。list2アイテムで選択されたすべてのアイテムは、送信時にTestModel.SelectedOptionsにバインドされます。

周りを見てください。Html.ListBoxForに関連するSOにはすでに多くの回答があります。たとえば 、ListBoxForで値を選択する際の課題

于 2012-08-22T04:21:45.027 に答える