Мой сценарий - это: у Меня есть два поля списка, то, которое содержит все мои объекты базы данных и пустой. Пользователь добавляет объекты, необходимые от полного поля списка до пустого поля списка.
Я использую форму для представления всех объектов, которые добавил пользователь.
Проблема, только выбранные пункты от поля списка отправлены. Таким образом, если пользователь отменяет выбор некоторых объектов, они привычка быть отправленным в форме. Мое представление похоже так:
<% 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
}
Я иду обо всем неправильным путем? Там лучший путь состоит в том, чтобы отправить объекты? Что Вы сделали бы?
Почему бы не иметь список элементов в флажках. Затем вы можете перебирать флажки в своем действии и брать все выбранные флажки.
<% 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
}
}
Потому что это просто поле выбора. Вы не можете разместить все значения в поле выбора. Вы должны использовать 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>