How to update the textbox value @Html.TextBoxFor(m => m.MvcGridModel.Rows[j].Id)

后端 未结 1 739
野趣味
野趣味 2021-01-26 20:39

I have problem, that the text box value doesn\'t get updated with the new value in the model. @Html.TextBoxFor(m => m.MvcGridModel.Rows[j].Id)

First the collection MvcG

1条回答
  •  走了就别回头了
    2021-01-26 20:55

    That's because HTML helpers such as TextBoxFor first look in the ModelState when binding their values and only after that in the model. So if in your POST action you attempt to modify some value that was part of the initial POST request you will have to remove it from the ModelState as well if you want those changes to take effect in the view.

    For example:

    [HttpPost]
    public ActionResult Foo(MyViewModel model)
    {
        // we change the value that was initially posted
        model.MvcGridModel.Rows[0].Id = 56;
    
        // we must also remove it from the ModelState if
        // we want this change to be reflected in the view
        ModelState.Remove("MvcGridModel.Rows[0].Id");
    
        return View(model);
    }
    

    This behavior is intentional and it is by design. This is what allows for example to have the following POST action:

    [HttpPost]
    public ActionResult Foo(MyViewModel model)
    {
        // Notice how we are not passing any model at all to the view
        return View();
    }
    

    and yet inside the view you get the values that the user initially entered in the input fields.

    There's also the ModelState.Clear(); method that you could use to remove all keys from the modelstate but be careful because this also removes any associated modelstate errors, so it is recommended to remove only values from the ModelState that you intend to modify inside your POST controller action.

    All this being said, in a properly designed application you should not need this. Because you should use the PRG pattern:

    [HttpPost]
    public ActionResult Index(MyViewModel model)
    {
        if (!ModelState.IsValid)
        {
            // there was some error => redisplay the view without any modifications
            // so that the user can fix his errors
            return View(model);
        }
    
        // at this stage we know that the model is valid. 
        // We could now pass it to the DAL layer for processing.
        ...
    
        // after the processing completes successfully we redirect to the GET action
        // which in turn will fetch the modifications from the DAL layer and render
        // the corresponding view with the updated values.
        return RedirectToAction("Index");
    }
    

    0 讨论(0)
提交回复
热议问题