Вернуть несколько значений флажка Html .CheckBoxFor в контроллер - PullRequest
1 голос
/ 23 февраля 2020

У меня есть представление, где пользователь должен выбрать несколько перечисленных элементов по флажкам, которые затем должны быть обработаны в контроллере.

Однако я не получаю значения, передаваемые в метод POST контроллера; При отладке список приходит в ноль.

При поиске ответов мне не удалось найти одно совпадение с C# и Html.CheckboxFor для нескольких значений.

Мне кажется, что это возможно, это мелочь, но я не могу понять это в течение нескольких дней.

Вот моя модель:

public class ShownListofTools// This List is given to the View to contain all Tools
{
    public IEnumerable<CheckboxItem> ToolsInShownList { get; set; } = new List<CheckboxItem>();         
}

public  class CheckboxItem //This Model is used to bring the Tools to the View
{
    public int ShownToolID { get; set; }
    public bool IsChecked { get; set; }
    public string DisplayName { get; set; }
    public int RemainingWorkTime { get; set; }
}

Это контроллер:

[HttpGet]
public ActionResult IndexforLend()
{
        // 1)
        var notwornouttools = db.Tools.Where(t => t.Max_Worktime - t.CurrentWorktime > 0); // List Tools that are not worn out yet
        var tools = notwornouttools.Where(t => t.UserID == null);  //refine Filter to all tools that are currently not lent by other users                                                                          
        // 2)
        List<CheckboxItem> SelectListTools = new List<CheckboxItem>(); //temporary list, to gather all needed items

        // 3)
        foreach(var item in tools)//work down the "tool" list from above
        {
            SelectListTools.Add(
                new CheckboxItem()//Add a new Checkbox Item
                {
                     DisplayName = item.Tooltype + " " + item.Diameter+"mm", //Transfer the Attributes from the "tool" list
                     ShownToolID = item.ID,
                    IsChecked = false,
                    RemainingWorkTime = item.Max_Worktime - item.CurrentWorktime,
                }
             );
        }

        //Checkboxlist.ToolsInShownList = SelectListTools; //The Checkbox Items are Added to the List "Checkboxlist".
        return View(SelectListTools); // The List "Checkboxlist" is transferred to the View.
}               

//POST: Add Tools to a User
[HttpPost]
public ActionResult IndexforLend([Bind(Include = "IsChecked,ShownToolID")] List<CheckboxItem> chklist)  //import from View, but make it numerable         
{            
    foreach(var item in chklist) //go through the entire Checkboxlist
    {
        if (item.IsChecked == true) // if the Checkbox was Checked - not sure if only checked objects are returned
        {
            var id = item.ShownToolID; // take the Tool-ID to the variable "id"

            foreach(var realtool in db.Tools) //go through all Tools in Database
            {
                if (realtool.ID == id) // if the Id from the Checkbox is found
                {
                    realtool.UserID = LoggedInUser.ID; // set the Foreign Key UserID to the ID of the Logged in User
                    db.Entry(realtool).State = EntityState.Modified;
                    db.SaveChanges();
                }
            }
        };
    }

    return RedirectToAction("Index");
}

Вид:

@model  List<WZ_Web2.Models.CheckboxItem>
   <p></p> 
<p></p>
<div>Please select the Tools you want to lend:</div>

@using (Html.BeginForm())
{
    @Html.AntiForgeryToken()
       <table class="table">
           @**@
        <tr>
            <th>
                Select
            </th>
            <th>
                Tool Name
            </th>
            <th>
                Remaining Work Time
            </th>                      
        </tr>

        @foreach (var item in Model)
        {
           <tr>
               <td>
                   @Html.CheckBoxFor(modelItem => item.IsChecked)
                   @Html.HiddenFor(modelItem => item.ShownToolID)

               </td>
               <td>
                   @Html.DisplayFor(modelItem => item.DisplayName)
               </td>              
               <td>
                   @Html.DisplayFor(modelItem => item.RemainingWorkTime)
               </td>

           </tr>
        }
    </table>
    <div class="col-md-offset-2 col-md-10">
        <input type="submit" value="submit" class="btn btn-default" />        
    </div>
}

1 Ответ

0 голосов
/ 23 февраля 2020

Использование foreach таким образом не приводит к созданию списка индексированных имен в сообщении. Когда вы выполняете итерацию по item и устанавливаете modelItem, в сообщении генерируется что-то вроде этого:

item.IsChecked = true & item.ShownToolID = 1 & item.IsChecked = false & item.ShownToolID = 2 .. .

Но контроллер ожидает индексированный список, например:

[0] .IsChecked = true & [0] .ShownToolID = 1 & [1] .IsChecked = false & [1] .ShownToolID = 2 ...

В результате mapper не может связать данные в вашем сообщении. Я разобрался, осмотрев пост. Попробуйте использовать for вместо ...

На ваш взгляд:

@for (int i = 0; i < Model.Count; i++ )
{
    <tr>
        <td>
            @Html.CheckBoxFor(item => Model[i].IsChecked)
            @Html.HiddenFor(item => Model[i].ShownToolID)

        </td>
        <td>
            @Html.DisplayFor(item => Model[i].DisplayName)
        </td>
        <td>
            @Html.DisplayFor(item => Model[i].RemainingWorkTime)
        </td>

    </tr>
}

В вашем контроллере:

[HttpPost]
public ActionResult IndexforLend(List<CheckboxItem> chklist)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...