asp.net-mvc – Sitecore MVC – 如何在页面上处理多个表单

前端之家收集整理的这篇文章主要介绍了asp.net-mvc – Sitecore MVC – 如何在页面上处理多个表单前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我一直在寻找Sitecore MVC但我仍然坚持如何处理我的页面有两个控制器渲染并且每个包含一个表单的情况.我希望各个控制器处理他们的HttpPost并在发布后返回整个页面.

我已经建立了一个简单的例子.两个控制器类似:

  1. public class ExampleController : Sitecore.Mvc.Controllers.SitecoreController
  2. {
  3. public override ActionResult Index()
  4. {
  5. return View("Index");
  6. }
  7.  
  8. [HttpPost]
  9. public ActionResult Index(string formPostData)
  10. {
  11. ViewBag.SaveForLater = formPostData;
  12. return Index();
  13. }
  14. }

视图看起来像这样:

  1. @using Sitecore.Mvc
  2. @using (Html.BeginRouteForm(Sitecore.Mvc.Configuration.MvcSettings.SitecoreRouteName,FormMethod.Post))
  3. {
  4. @Html.AntiForgeryToken()
  5. var term = ViewBag.SaveForLater as string;
  6. if (!string.IsNullOrEmpty(term))
  7. {
  8. <p>Submitted: @term</p>
  9. }
  10. <p>
  11. @Html.Sitecore().FormHandler("Example","Index")
  12. <input type="text" name="formPostData" placeholder="Enter something" />
  13. <input type="submit" name="submit" value="Search" />
  14. </p>
  15. }

使用此设置,两个表单都提交其数据,但返回的页面仅包含部分视图,而不是整个页面.

如果我用@ Html.Sitecore().FormHandler()替换@ Html.Sitecore().FormHandler(“Example”,“Index”)行,则返回整个页面,但处理两个表单的post动作.

这两种情况都不理想.我必须遗漏一些东西,并会欣赏指针.

解决方法

不幸的是,有多种方法可以与Sitecore MVC集成,而Sitecore没有提供许多最佳实践示例.一个例子你可以找到 here.

在我们的项目中,我们做的有点不同,因为我们希望尽可能多地使用默认ASP.NET MVC中的约定等.我试着在这篇文章中包含一个完整的简单例子.

我们使用当前操作和当前控制器向表单添加两个不同的隐藏字段,视图如下所示:

  1. @model Website.Models.Testviewmodel
  2.  
  3. @using (Html.BeginForm())
  4. {
  5. @Html.LabelFor(model => model.Text)
  6. @Html.TextBoxFor(model => model.Text)
  7.  
  8. <input type="submit" value="submit" />
  9.  
  10. <input type="hidden" name="fhController" value="TestController" />
  11. <input type="hidden" name="fhAction" value="Index" />
  12. }

有了这个简单的viewmodel:

  1. namespace Website.Models
  2. {
  3. public class Testviewmodel
  4. {
  5. public string Text { get; set; }
  6. }
  7. }

然后我们创建了一个自定义属性,用于检查当前控制器/操作是否与发布的相同:

  1. public class ValidateFormHandler : ActionMethodSelectorAttribute
  2. {
  3. public override bool IsValidForRequest(ControllerContext controllerContext,MethodInfo methodInfo)
  4. {
  5. var controller = controllerContext.HttpContext.Request.Form["fhController"];
  6. var action = controllerContext.HttpContext.Request.Form["fhAction"];
  7.  
  8. return !string.IsNullOrWhiteSpace(controller)
  9. && !string.IsNullOrWhiteSpace(action)
  10. && controller == controllerContext.Controller.GetType().Name
  11. && methodInfo.Name == action;
  12. }
  13. }

然后控制器操作获取属性

  1. namespace Website.Controllers
  2. {
  3. public class TestController : Controller
  4. {
  5. public ActionResult Index()
  6. {
  7. return View();
  8. }
  9.  
  10. [HttpPost]
  11. [ValidateFormHandler]
  12. public ActionResult Index(Testviewmodel model)
  13. {
  14. return View(model);
  15. }
  16. }
  17. }

我们总是返回ASP.NET MVC解析的视图.按照惯例,这是与文件夹中具有与控制器同名的操作同名的视图.

这种方法对我们非常有效.如果你想添加AntiForgeryToken,这也可以.

猜你在找的asp.Net相关文章