formcollection только содержит выбранные html.listbox значения объектов? MVC

Мой сценарий - это: у Меня есть два поля списка, то, которое содержит все мои объекты базы данных и пустой. Пользователь добавляет объекты, необходимые от полного поля списка до пустого поля списка.

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

Проблема, только выбранные пункты от поля списка отправлены. Таким образом, если пользователь отменяет выбор некоторых объектов, они привычка быть отправленным в форме. Мое представление похоже так:

<% using (Html.BeginForm("MyAction", "MyController"))
   { %>

    <%= Html.ListBox("AddedItems", Model.Items)%>

    <input type="submit" value="Submit" name="SubmitButton"/>
<% } %>

Мой Контроллер похож так:

public ActionResult MyAction(FormCollection formCollection)
{
    var addedItems = formCollection["AddedItems"].Split(',');

    //....more code that does stuff with the items
}

Я иду обо всем неправильным путем? Там лучший путь состоит в том, чтобы отправить объекты? Что Вы сделали бы?

13
задан Darcy 4 March 2010 в 22:09
поделиться

2 ответа

Почему бы не иметь список элементов в флажках. Затем вы можете перебирать флажки в своем действии и брать все выбранные флажки.

<% foreach(var item in Model.Items) { %>

   <%= Html.CheckBox(String.Format("ItemID.{0}", item.ID)) %> // each item tagged by the items id

<% } %>

public ActionResult MyAction(FormCollection formCollection)
{

            foreach (var key in collection.AllKeys.Where(k => !k.Contains("SubmitButton")).ToArray<string>())
            {
                 // iterates thru check boxes we got rid of the button 

            }
}
1
ответ дан 1 December 2019 в 21:24
поделиться

Потому что это просто поле выбора. Вы не можете разместить все значения в поле выбора. Вы должны использовать javascript, чтобы перехватить добавленные элементы и сохранить их в скрытом вводе.

Непроверенный код, но я думаю, он вам поможет.

<script type="text/javascript">
    function addItem() {
        var allItems = document.getElementById("AllItems");
        var op = allItems.options[allItems.selectedIndex];
        var hdSelectedItems = document.getElementById("hdSelectedItems");
        var lbSelectedItems = document.getElementById("lbSelectedItems");

        lbSelectedItems.options[lbSelectedItems.options.length] = op;

        if (hdSelectedItems.value != '') {
             hdSelectedItems.value += ","
        }
        hdSelectedItems.value += op.value;
    }
</script>
<%= Html.Hidden("hdSelectedItems") %>
<%= Html.ListBox("AllItems", Model.Items)%>
<%= Html.ListBox("lbSelectedItems") %>
<a href="#" onclick="addItem(); return false;">Add</a>
2
ответ дан 1 December 2019 в 21:24
поделиться
Другие вопросы по тегам:

Похожие вопросы: