J'ai un formulaire de base pour lequel je souhaite gérer des boutons à l'intérieur du formulaire en appelant la méthode ActionResult
dans la classe Controller
associée de la vue. Voici le code HTML5 suivant pour le formulaire:
<h2>Welcome</h2>
<div>
<h3>Login</h3>
<form method="post" action= <!-- what goes here --> >
Username: <input type="text" name="username" /> <br />
Password: <input type="text" name="password" /> <br />
<input type="submit" value="Login">
<input type="submit" value="Create Account"/>
</form>
</div>
<!-- more code ... -->
Le code Controller
correspondant est le suivant:
[HttpPost]
public ActionResult MyAction(string input, FormCollection collection)
{
switch (input)
{
case "Login":
// do some stuff...
break;
case "Create Account"
// do some other stuff...
break;
}
return View();
}
vous utilisez HTML Helper et avez
@using(Html.BeginForm())
{
Username: <input type="text" name="username" /> <br />
Password: <input type="text" name="password" /> <br />
<input type="submit" value="Login">
<input type="submit" value="Create Account"/>
}
ou utilisez l'url helper
<form method="post" action="@Url.Action("MyAction", "MyController")" >
Html.BeginForm
possède plusieurs (13) substitutions pour lesquelles vous pouvez spécifier plus d'informations, par exemple, une utilisation normale lors du téléchargement de fichiers utilise:
@using(Html.BeginForm("myaction", "mycontroller", FormMethod.Post, new {enctype = "multipart/form-data"}))
{
< ... >
}
Si vous ne spécifiez aucun argument, la Html.BeginForm()
créera un formulaire POST
qui pointe sur votre contrôleur actuel et l'action actuelle . Par exemple, supposons que vous ayez un contrôleur appelé Posts
et une action appelée Delete
public ActionResult Delete(int id)
{
var model = db.GetPostById(id);
return View(model);
}
[HttpPost]
public ActionResult Delete(int id)
{
var model = db.GetPostById(id);
if(model != null)
db.DeletePost(id);
return RedirectToView("Index");
}
et votre page html serait quelque chose comme:
<h2>Are you sure you want to delete?</h2>
<p>The Post named <strong>@Model.Title</strong> will be deleted.</p>
@using(Html.BeginForm())
{
<input type="submit" class="btn btn-danger" value="Delete Post"/>
<text>or</text>
@Url.ActionLink("go to list", "Index")
}
Ici, je suis essentiellement en train d'envelopper un bouton dans un lien. L'avantage est que vous pouvez publier différentes méthodes d'action dans le même formulaire.
<a href="Controller/ActionMethod">
<input type="button" value="Click Me" />
</a>
Ajout de paramètres:
<a href="Controller/ActionMethod?userName=ted">
<input type="button" value="Click Me" />
</a>
Ajout de paramètres à partir d'un modèle non énuméré:
<a href="Controller/[email protected]">
<input type="button" value="Click Me" />
</a>
Vous pouvez également faire de même pour un modèle énuméré. Il vous suffira de référencer une seule entité en premier. Bon codage!