El primer parámetro de Html.RadioButtonFor() debe ser el nombre de propiedad que está utilizando, y el segundo parámetro debe ser el valor de ese botón de opción específico. Entonces tendrán el mismo valor de atributo de nombre y el ayudante seleccionará el botón de opción dado cuando/si coincide con el valor de la propiedad.
Ejemplo:
<div class="editor-field">
<%= Html.RadioButtonFor(m => m.Gender, "M") %> Male
<%= Html.RadioButtonFor(m => m.Gender, "F") %> Female
</div>
Aquí hay un ejemplo más específico:
Hice un proyecto MVC rápida llamado "DeleteMeQuestion" (DeleteMe prefijo, así que sé que puedo quitarlo más adelante después de Me olvido de eso).
me hizo el siguiente modelo:
namespace DeleteMeQuestion.Models
{
public class QuizModel
{
public int ParentQuestionId { get; set; }
public int QuestionId { get; set; }
public string QuestionDisplayText { get; set; }
public List<Response> Responses { get; set; }
[Range(1,999, ErrorMessage = "Please choose a response.")]
public int SelectedResponse { get; set; }
}
public class Response
{
public int ResponseId { get; set; }
public int ChildQuestionId { get; set; }
public string ResponseDisplayText { get; set; }
}
}
Hay un sencillo validador rango en el modelo, sólo por diversión. El siguiente, hice la siguiente controlador:
namespace DeleteMeQuestion.Controllers
{
[HandleError]
public class HomeController : Controller
{
public ActionResult Index(int? id)
{
// TODO: get question to show based on method parameter
var model = GetModel(id);
return View(model);
}
[HttpPost]
public ActionResult Index(int? id, QuizModel model)
{
if (!ModelState.IsValid)
{
var freshModel = GetModel(id);
return View(freshModel);
}
// TODO: save selected answer in database
// TODO: get next question based on selected answer (hard coded to 999 for now)
var nextQuestionId = 999;
return RedirectToAction("Index", "Home", new {id = nextQuestionId});
}
private QuizModel GetModel(int? questionId)
{
// just a stub, in lieu of a database
var model = new QuizModel
{
QuestionDisplayText = questionId.HasValue ? "And so on..." : "What is your favorite color?",
QuestionId = 1,
Responses = new List<Response>
{
new Response
{
ChildQuestionId = 2,
ResponseId = 1,
ResponseDisplayText = "Red"
},
new Response
{
ChildQuestionId = 3,
ResponseId = 2,
ResponseDisplayText = "Blue"
},
new Response
{
ChildQuestionId = 4,
ResponseId = 3,
ResponseDisplayText = "Green"
},
}
};
return model;
}
}
}
Finalmente, hice la siguiente opinión de que hace uso del modelo:
<%@ Page Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage<DeleteMeQuestion.Models.QuizModel>" %>
<asp:Content ContentPlaceHolderID="TitleContent" runat="server">
Home Page
</asp:Content>
<asp:Content ContentPlaceHolderID="MainContent" runat="server">
<% using (Html.BeginForm()) { %>
<div>
<h1><%: Model.QuestionDisplayText %></h1>
<div>
<ul>
<% foreach (var item in Model.Responses) { %>
<li>
<%= Html.RadioButtonFor(m => m.SelectedResponse, item.ResponseId, new {id="Response" + item.ResponseId}) %>
<label for="Response<%: item.ResponseId %>"><%: item.ResponseDisplayText %></label>
</li>
<% } %>
</ul>
<%= Html.ValidationMessageFor(m => m.SelectedResponse) %>
</div>
<input type="submit" value="Submit" />
<% } %>
</asp:Content>
Como entiendo su contexto, tiene alguna pregunta con una lista de respuestas disponibles Cada respuesta dictará la siguiente pregunta. Espero que eso tenga sentido en mi modelo y en los comentarios TODO.
Esto le da los botones de opción con el mismo atributo de nombre, pero diferentes atributos de identificación.
¿Por qué no puede usar 'Html.RadioButton' en su lugar? – Ahmad
Dado que es una vista fuertemente tipada, intento hacer que los datos vuelvan a llenarse en el controlador. ¡Aunque estoy abierto a cualquier sugerencia! –