HiddenFor(x => x.Id) is being populated by the Url

2020-02-01 04:14发布

public ActionResult SomeAction(int Id){
    //Id is set to 2

    var model = //get some thing from db using Id(2);
    //Now model.Id is set to 9;

    return View(model);
}

----------View----------
@Html.HiddenFor(x => x.Id)

When I view source this hidden field is set to 2 not 9. How do I get it to map to the model instead of mapping to the URL routing info?

P.S. I'd prefer not to rename parameters because then I lose my nice looking url's unless i change the routing info. I have done that and it does work, but not what I want.

3条回答
Luminary・发光体
2楼-- · 2020-02-01 04:34

You could try this below

<input id="Id" type="hidden" value="@Model.Id" />

May not be exactly what you want but essentially does the same thing.

查看更多
甜甜的少女心
3楼-- · 2020-02-01 04:37

When an Action gets called the framework builds a ModelStateCollection based on the query-string values, post-data, routing values etc. And this ModelStateCollection will be passed to the View. All the HTML input helpers try to the get the values from the ModelStateCollection first, before trying to get the values from the actual model.

Because your input model is the int id but the output model is some new model the helpers will use the values from the ModelStateCollection (from the query string) because the propery names Id are match.

To make it work you have to manually clear the ModelStateCollection before returning the new model to the view:

public ActionResult SomeAction(int Id){
    //Id is set to 2

    ModelState.Clear();

    var model = //get some thing from db using Id(2);
    //Now model.Id is set to 9;

    return View(model);
}
查看更多
兄弟一词,经得起流年.
4楼-- · 2020-02-01 04:45

You can use TextBoxFor and make it hidden using CSS as

@Html.TextBoxFor(x => x.Id, new { @style="visibility:hidden; width:4px;"})

It worked for me.

查看更多
登录 后发表回答