使用编辑器加载选定的单选按钮c#

时间:2012-10-26 10:49:29

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

关于这个问题:

StackOverflow - Grouping radio buttons in c# mvc

我现在已经设法将表单中的选定选项加载并保存到数据库中,但现在用户可能需要编辑它。

如何使用所选用户的选项加载视图?我看不到你可以在哪里设置选择的答案。在加载时,我将获得选择的默认值

2 个答案:

答案 0 :(得分:1)

使用此:

<%= Html.RadioButtonFor(m => m.Something, "something", new { Checked = "checked" })%>

答案 1 :(得分:1)

您可以在SelectedAnswer操作中为每个Course设置GET属性值,而EditorTemplate将负责其余操作。

public ActionResult Index()
{
    var vm= new OrderViewModel();

    //the below is hard coded for DEMO. you may get the data from some  
    //other place and set the course and options

    var q1 = new Course { ID = 1, Name= "Starters" };
    q1.Options.Add(new Option{ ID = 12, Title = "Prawn Cocktail " });
    q1.Options.Add(new Option{ ID = 13, Title = "Soup" });
    q1.SelectedAnswer = 13; //to do : get the selected answer value from DB

    vm.Courses.Add(q1);     

    var q2 = new Course { ID = 1, Name= "Mains" };
    q2.Options.Add(new Option{ ID = 42, Title = "Beef" });
    q2.Options.Add(new Option{ ID = 43, Title = "Lamp" });
    q2.SelectedAnswer = 16;// to do :get the selected answer value from DB

    vm.Courses.Add(q2);

   return View(vm);           
}

您的编辑器模板无需更改。它与上一个答案保持一致。

@model Course
<div>
    @Html.HiddenFor(x=>x.ID)
    <h3> @Model.Name</h3>
    @foreach (var a in Model.Options)
    {
       <p>
          @Html.RadioButtonFor(b=>b.SelectedAnswer,a.ID)  @a.Title
       </p>
    }
</div>