通过RouteValueDictionary发送单个值

时间:2014-03-07 19:37:08

标签: asp.net-mvc asp.net-mvc-3 razor routevalues

我的ViewModel的一个属性是一个数组,不幸的是,每次我回发到控制器时都是null。我想到了一个简单的黑客,我将值放入一个逗号分隔的字符串中。

这适用于我们的分页插件,后者使用Index回发到我们的RouteValueDictionary方法。但是,它不会在Html.BeginForm帮助程序中工作,它会回发到不同的控制器操作(Update方法)。

查看

@*Since we can't send arrays or complex objects break array down into string for RouteValueDictionary*@
var channelCodes = "";
for (int i = 0; i < Model.searchChannelCode.Length; i++)
{
    channelCodes += Model.searchChannelCode[i];

    if (i + 1 < Model.searchChannelCode.Length)
    {
        channelCodes += ",";
    }
}  

@*The 'searchChannelCodesPagin' variable from this RouteValueDictionary always posts back as null
using (Html.BeginForm("Update", "ZipCodeTerritory", new RouteValueDictionary()
    {
        {"searchChannelCodesPaging", channelCodes }
    }, FormMethod.Post, new {id = "UpdateForm"}))
{
    @Html.HiddenFor(model => model.searchZip)
    @Html.HiddenFor(model => model.searchTerritory)
    @Html.HiddenFor(model => model.searchState)
    @Html.HiddenFor(model => model.searchActiveOnly)
    @Html.HiddenFor(model => model.zipCodeTerritory)

    <div id="cloneBox">
        <div id="rw1">
            @Html.LabelFor(model => model.newTerritory)
            @Html.TextBoxFor(model => model.newTerritory, new { style = "width: 30px;padding-left:10px;", maxLength = 3 })
            @Html.LabelFor(model => model.newDescription)
            @Html.TextBoxFor(model => model.newDescription, new { style = "width: 250px;padding-left:10px;", maxLength = 30 })  
            @Html.LabelFor(model => model.newEffectiveDate)     
            @Html.TextBoxFor(model => model.newEffectiveDate, new { style = "width: 80px;padding-left:10px;" }) 
            <div id="rw2" style="padding-top: 10px;">
                @Html.LabelFor(model => model.newChannelCode)
                @Html.DropDownListFor(model => model.newChannelCode, Model.ChannelCodes, " ")
                @Html.LabelFor(model => model.newStateCode)
                @Html.DropDownListFor(model => model.newStateCode, Model.StateCodes, "  ")
                @Html.LabelFor(model => model.newEndDate)
                @Html.TextBoxFor(model => model.newEndDate, new { style = "width: 80px;" })
            </div>                                 
        </div>
    </div>
    <br/>
    <div id="buttonDiv">
        <button type="submit" id="CloneButton" name="button" value="clone">Apply New Data</button>
        <button type="submit" id="deleteButton" name="button" value="delete">Delete Selected Items</button> 
        <button type="submit" id="removeButton" name="button" value="removeErrors">Remove Selected Errors</button>           
    </div>

}

控制器

上面的格式发布到此控制器操作。 searchChannelCodePaging变量每次都为null。

    [HttpPost]
    public ActionResult Update(ZipCodeIndex updateZip, string button, string searchChannelCodesPaging)
    {

2 个答案:

答案 0 :(得分:1)

由于你正在发帖子,最简单的方法就是添加隐藏字段:

@Html.HiddenFor("searchChannelCodesPaging", searchChannelCodesPaging);

作为路由值,您可能需要通过以下两种方法之一在控件中明确地获取它。这些对象可以在Controller类中直接访问。

RouteData.Values("searchChannelCodesPaging")
Request.QueryString.Get("searchChannelCodesPaging");

答案 1 :(得分:1)

您不必将数组类型模型参数序列化为CSV字符串,以使其发布到控制器。你可以这样做:

@for (var i = 0; i < Model.searchChannelCode.Length; i++)
{
    @Html.HiddenFor(m => m.searchChannelCode[i]);
}