【问题标题】:MVC 5 send radio button string value to post action methodMVC 5将单选按钮字符串值发送到发布操作方法
【发布时间】:2015-06-30 13:18:02
【问题描述】:

我已经阅读了几个关于这个问题的问题和答案,但没有一个能让我更接近解决这个问题。我的问题是我似乎无法将 RadioButtonFor 检查值保留到 post 操作方法。有很多不相关的东西,所以我会尝试将其归结为相关问题。

所以我有一个像这样的ViewModel

    public class QEventHandlerVM
    {
       //Removed unrelated
       public QueueEventHandlerModel QEventHandler { get; set; }           
       public string SelectedOption { get; set; }
    }

编辑视图的Get Method。我在这里设置SelectedOption,这样我就可以在前端使用它。任务是根据SelectedOption 值显示和隐藏div。据我所知,这部分工作正常,值被设置并通过 jQuery 在视图中使用。

    [HttpGet]
    public ActionResult Edit(int id)
    {
        try
        {
            //Removed unrelated...
            QueueEventHandlerModel model;
            QEventHandlerVM vm = new QEventHandlerVM();

            ApiCommunicator.Get("QueueEventHandlers/" + id, out model);

            vm.QEventHandler = model;
            if (...)                
                vm.SelectedOption = "toQueue";

            if (...)                
                vm.SelectedOption = "redirection";

            if (...)
                vm.SelectedOption = "hangup";

            return View(vm);
        }
        catch (HttpResponseUnsuccessfulException e){...}

    }

Edit view 简化版:

        @model Foo.WebSites.Web.Views.QueueEventHandlers.QEventHandlerVM

        @using (Html.BeginForm())
        {
            @Html.AntiForgeryToken()

            //Unrelated stuff...
            @Html.HiddenFor(s => s.SelectedOption)

            @Html.RadioButtonFor(s => s.SelectedOption, "toQueue", new { id = "rdToQueue", @class = "q-event" })
            <label for="rdToQueue">Transfer call to queue</label>

            @Html.RadioButtonFor(s => s.SelectedOption, "redirect", new { id = "rdRedirect", @class = "q-event" })
            <label for="rdRedirect">Transfer call to destination</label>

            @Html.RadioButtonFor(s => s.SelectedOption, "hangup", new { id = "rdHangup", @class = "q-event" })
            <label for="rdHangup">Hangup</label>

            <button type="submit" class="btn btn-primary btn-sm">Save</button>
        }

Post 方法

    [HttpPost]
    [ValidateAntiForgeryToken]
    public ActionResult Edit(QEventHandlerVM model, int id)
    {
        if (!ModelState.IsValid) {... return View(model); }

        if (model.SelectedOption == "hangup" || model.SelectedOption == "redirection")
        {
            model.QEventHandler.QueueId = null;
        }
        else if (model.SelectedOption == "toQueue")
        {
            model.QEventHandler.Phrase = string.Empty;
            model.QEventHandler.Redirection = string.Empty;
        }
        else if (model.SelectedOption == "hangup")
        {
            model.QEventHandler.Redirection = string.Empty;
            model.QEventHandler.QueueId = null;
        }

        try {// Update}
        catch (HttpResponseUnsuccessfulException e){...}
    }

现在,这里的 SelectedOption 值与 Get 方法中的值相同。我可能错过了一些简单的事情,并且很可能有更好的方法来解决这个问题。

提前致谢。

【问题讨论】:

  • 可能是错字,但第二个单选按钮应该是 "redirection" 而不是 "redirect"

标签: c# .net asp.net-mvc razor


【解决方案1】:

这是因为您的SelectedOption 属性有一个HiddenFor 关联的编辑字段。只需删除 HiddenFor 即可:

@Html.HiddenFor(s => s.SelectedOption)

【讨论】:

  • 太好了。非常感谢
  • @brroshan 没问题,很高兴我能帮上忙!
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2023-04-09
  • 2011-02-16
  • 2014-02-02
  • 2013-03-16
  • 2011-10-13
相关资源
最近更新 更多