我们知道,BeginForm()方法能创建一个Form标签,因此可以结合表单级的方法,在这个页面中。我一直在考虑Html.BeginForm()方法和Ajax.BeginForm()方法在MVC3中有什么不同。读了很多博客,很多人都强调了一件事:Ajax Form,Form被提交是使用了JavaScript异步提交的。

Html Form和 Ajax Form区别:

一,我做了一个简单的Demo来示范:

Step1:创建一个MVC项目

Step2:创建一个视图名为TestHtmlView.cshtml,此视图的Form表单使用Html.BeginForm()创建。此例子的操作是:当提交此表单时进行重定向;

  1. <span style="font-family:KaiTi_GB2312;font-size:18px;">@{
  2. ViewBag.Title = "Home Page";
  3. }
  4. <h2>@ViewBag.Message</h2>
  5. <p>
  6. @using(Html.BeginForm("TestHtmlRedirect", "Test",FormMethod.Post, null))
  7. {
  8. <input type="submit"value="Html PsBk Click" />
  9. }
  10. </p></span>

Step3:定义两个action方法,一个用于返回创建的视图,一个用于响应表单提交;

  1. <span style="font-family:KaiTi_GB2312;font-size:18px;"> //This section of code is forTestHtmlView.cshtml
  2. public ActionResult TestHtmlView()
  3. {
  4. ViewBag.Message = "HtmlForm——This is a HTML form";
  5. return View();
  6. }
  7. [HttpPost]
  8. public ActionResult TestHtmlRedirect()
  9. {
  10. returnRedirectToAction("TestAjaxView", "Test", null);
  11. }
  12. //End of the section of code forTestHtmlView.cshtml</span>

看一下TestHtmlRedirect()方法的实现体,我们想从该视图重定向到另一个视图TestAjaxView.cshtml。

Step4:创建一个视图名为AjaxHtmlView.cshtml,此视图的Form表单使用Ajax.BeginForm()创建。

  1. <span style="font-family:KaiTi_GB2312;font-size:18px;">@{
  2. ViewBag.Title = "Test Page";
  3. }
  4. <scriptsrcscriptsrc="@Url.Content("~/Scripts/jquery.unobtrusive-ajax.min.js")"type="text/javascript"></script>
  5. <h2>@ViewBag.Message</h2>
  6. <p>
  7. @using(Ajax.BeginForm("TestAjaxRedirect", "Test",FormMethod.Post, null))
  8. {
  9. <input type="submit"value="Ajax PsBk Click" />
  10. }
  11. </p></span>

Step5:如果想让此Ajax Form正确工作,能达到预期,那么还需要在AjaxHtmlView.cshtml中添加此JS文件引用

<scriptsrc="@Url.Content("~/Scripts/jquery.unobtrusive-ajax.min.js")"type="text/javascript"></script>

还要确保在Web.Config文件中支持JS的执行,需要此配置文件中添加如下标签:

  1. <span style="font-family:KaiTi_GB2312;font-size:18px;">  <!--启用客户端验证,Start。。。-->
  2. <addkeyaddkey="ClientValidationEnabled" value="true"/>
  3. <!--支持JavaScript的执行-->
  4. <addkeyaddkey="UnobtrusiveJavaScriptEnabled" value="true"/></span>

Step6:定义两个action方法,一个用于返回创建的视图,一个用于响应表单提交;

  1. <span style="font-family:KaiTi_GB2312;font-size:18px;">//This section ofcode is for TestAjaxView.cshtml
  2. public ActionResult TestAjaxView()
  3. {
  4. ViewBag.Message = "AjaxForm——This is a AJAX form";
  5. return View();
  6. }
  7. [HttpPost]
  8. public ActionResult TestAjaxRedirect()
  9. {
  10. returnRedirectToAction("About", "Test", null);
  11. }
  12. //End of Section of code forTestAjaxView.cshtml</span>

看一下TestAjaxRedirect()方法的实现体,我们想从该视图重定向到另一个视图About.cshtml。

(附录:

(1)About.cshtml:

  1. <span style="font-family:KaiTi_GB2312;font-size:18px;">@{
  2. ViewBag.Title = "关于我们";
  3. }
  4. <h2>关于</h2>
  5. <p>
  6. 将内容放置在此处。
  7. </p></span>

(2)Test控制器中添加About方法:

  1. <span style="font-family:KaiTi_GB2312;font-size:18px;">public ActionResult About() {
  2. return View();
  3. }</span>

(3)Global.asax

  1. <span style="font-family:KaiTi_GB2312;font-size:18px;">using System;
  2. usingSystem.Collections.Generic;
  3. using System.Linq;
  4. using System.Web;
  5. usingSystem.Web.Mvc;
  6. usingSystem.Web.Routing;
  7. namespaceComplaintManageSystem
  8. {
  9. // 注意: 有关启用 IIS6 或 IIS7 经典模式的说明,
  10. // 请访问 http://go.microsoft.com/?LinkId=9394801
  11. public class MvcApplication :System.Web.HttpApplication
  12. {
  13. public static voidRegisterGlobalFilters(GlobalFilterCollection filters)
  14. {
  15. filters.Add(newHandleErrorAttribute());
  16. }
  17. public static voidRegisterRoutes(RouteCollection routes)
  18. {
  19. routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
  20. routes.MapRoute(
  21. "Default", // 路由名称
  22. "{controller}/{action}/{id}", // 带有参数的 URL
  23. new { controller ="Test", action = "TestHtmlView", id =UrlParameter.Optional } // 参数默认值
  24. );
  25. }
  26. protected void Application_Start()
  27. {
  28. AreaRegistration.RegisterAllAreas();
  29. RegisterGlobalFilters(GlobalFilters.Filters);
  30. RegisterRoutes(RouteTable.Routes);
  31. }
  32. }
  33. }
  34. </span>

Step7:让我们开始执行程序,观察执行结果,如下图1:

  1

当我点击图1中“Html PsBk Click”按钮时,TestHtmlRedirect()方法被调用,并且视图重定向到TestAjaxView.cshtml,如下图:

 2

现在,考虑一件事,当我点击图2中"Ajax PsBk Click"按钮时,是否会发生同样的事,视图会重定向到About.cshtml?点击后,发现这件事并没有发生。

点击按钮后,TestAjaxRedirect()方法被调用,重定向语句段执行,但是视图并没有重定向。原因是:表单的提交使用了JavaScript的异步提交。正如我们看到的,操作的执行是异步的,Ajaxforms是适用于多种情况的,比如你需要修改或保存时是异步操作,但是不能重定向到其他表单。

二,下面,我们再做一个Demo,让我们测试一下Htmlforms和Ajax forms在执行修改操作时会有何不同。

Step8:定义一个实体 PersonnelModel

  1. <span style="font-family:KaiTi_GB2312;font-size:18px;">using System;
  2. usingSystem.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. usingSystem.Reflection;
  6. using Model.Adapter;
  7. namespaceModel.Entity
  8. {
  9. public class PersonnelModel
  10. {
  11. public string UserName { get; set; }
  12. public string MailAdress { get; set; }
  13. }
  14. }</span>

Step9:再分别定义Html和Ajax视图

HtmlViewModel.cshtml:

  1. <span style="font-family:KaiTi_GB2312;font-size:18px;">@modelHtmlVsAjaxBeginForm.Models.PersonnelModel
  2. @{
  3. ViewBag.Title ="HtmlViewModel";
  4. }
  5. <h2>HtmlViewModel</h2>
  6. @using (Html.BeginForm("HtmlViewModel","Home",null))
  7. {
  8. @Html.ValidationSummary(true)
  9. <fieldset>
  10. <legend>PersonnelModel</legend>
  11. <divclassdivclass="editor-label">
  12. @Html.LabelFor(model =>model.UserName)
  13. </div>
  14. <divclassdivclass="editor-field">
  15. @Html.EditorFor(model =>model.UserName)
  16. @Html.ValidationMessageFor(model => model.UserName)
  17. </div>
  18. <divclassdivclass="editor-label">
  19. @Html.LabelFor(model =>model.MailAdress)
  20. </div>
  21. <divclassdivclass="editor-field">
  22. @Html.EditorFor(model =>model.MailAdress)
  23. @Html.ValidationMessageFor(model => model.MailAdress)
  24. </div>
  25. </fieldset>
  26. <p>
  27. <input type="submit"value="Html Form Action" />
  28. </p>
  29. }</span>

AjaxViewModel.cshtml:

  1. <span style="font-family:KaiTi_GB2312;font-size:18px;">@model Model.Entity.PersonnelModel
  2. @{
  3. ViewBag.Title = "AjaxViewModel";
  4. }
  5. <script src="@Url.Content("~/Scripts/jquery.unobtrusive-ajax.min.js")" type="text/javascript"></script>
  6. <h2>AjaxViewModel</h2>
  7. @using (Ajax.BeginForm("AjaxViewModel", "Test", new AjaxOptions { UpdateTargetId = "result" }))
  8. {
  9. @Html.ValidationSummary(true)
  10. <fieldset>
  11. <legend>PersonnelModel</legend>
  12. <div id="result"></div>
  13. <div class="editor-label">
  14. @Html.LabelFor(model => model.UserName)
  15. </div>
  16. <div class="editor-field">
  17. @Html.EditorFor(model => model.UserName)
  18. @Html.ValidationMessageFor(model => model.UserName)
  19. </div>
  20. <div class="editor-label">
  21. @Html.LabelFor(model => model.MailAdress)
  22. </div>
  23. <div class="editor-field">
  24. @Html.EditorFor(model => model.MailAdress)
  25. @Html.ValidationMessageFor(model => model.MailAdress)
  26. </div>
  27. </fieldset>
  28. <p>
  29. <input type="submit" value="Ajax Form Action" />
  30. </p>
  31. }</span>

Step10:定义两个action方法,目的均为返回数据内容,显示在各自视图中

  1. <span style="font-family:KaiTi_GB2312;font-size:18px;">//HTML Form Method
  2. //Purpose: Will return the belowcontent, once after the method triggered.
  3. [HttpPost]
  4. public ActionResultHtmlViewModel(PersonnelModel Pmodel)
  5. {
  6. return Content("Hi" + Pmodel.UserName + ", Thanks for the details, a mail will be sentto " + Pmodel.MailAdress + " with all the login details.","text/html");
  7. }
  8. //AJAX Form Method
  9. //Purpose: Will return the belowcontent, once after the method triggered.
  10. [HttpPost]
  11. public ActionResultAjaxViewModel(PersonnelModel Pmodel)
  12. {
  13. return Content("Hi" + Pmodel.UserName + ", Thanks for the details, a mail will be sentto " + Pmodel.MailAdress + " with all the login details.","text/html");
  14. }</span>

Step11:现在分别运行这两个视图,点击各自按钮,观察执行效果:

HtmlViewModel.cshtml加载:

文本框中输入数据:

点击“Html Form Action”按钮后,运行效果:

弹出了新页面,将返回的数据显示

AjaxViewModel.cshtml加载:

文本框中输入数据:

点击“Ajax Form Action”按钮后,运行效果:

页面无刷新,将返回的数据显示在原页面

注:当然在Html forms中也可以产生如上Ajaxfroms中的效果,例如:写js代码,使用Ajax请求函数)

总结:

Html.BeginForm与Ajax.BeginForm都是MVC架构中的表单元素;

区别:Html.BeginForm是普通的表单提交,而Ajax.BeginForm是支持异步的表单提交;

Ajax.BeginForm()优点:不用再自己去用JQ代码了,直接用MVC自代的Ajax.BeginForm就可以很容易的完成一个异步的表单提交动作。

Html.BeginForm() vs Ajax.BeginForm() in MVC3的更多相关文章

  1. 爱上MVC3系列~Html.BeginForm与Ajax.BeginForm

    Html.BeginForm与Ajax.BeginForm都是MVC架构中的表单元素,它们从字面上可以看到区别,即Html.BeginForm是普通的表单提交,而Ajax.BeginForm是支持异步 ...

  2. 转:MVC3系列:~Html.BeginForm与Ajax.BeginForm

    Html.BeginForm与Ajax.BeginForm都是MVC架构中的表单元素,它们从字面上可以看到区别,即Html.BeginForm是普通的表单提交,而Ajax.BeginForm是支持异步 ...

  3. MVC3系列~Html.BeginForm与Ajax.BeginForm

    Html.BeginForm与Ajax.BeginForm都是MVC架构中的表单元素,它们从字面上可以看到区别,即Html.BeginForm是普通的表单提交,而Ajax.BeginForm是支持异步 ...

  4. Html.BeginForm())与Ajax.BeginForm()

     一.@using (Html.BeginForm())参数示例 1.指定表单提交方式和路径等 @using (Html.BeginForm("Index", "Home ...

  5. MVC小系列(十一)【Html.BeginForm与Ajax.BeginForm】

    Html.BeginForm与Ajax.BeginForm都是mvc的表单元素,前者是普通的表单提交,而后者是支持异步的表单提交,直接用mvc自带的Ajax.BeginForm就可以很容易完成一个异步 ...

  6. MVC Html.BeginForm 与 Ajax.BeginForm 使用总结

    最近采用一边工作一边学习的方式使用MVC5+EF6做一个Demo项目, 期间遇到不少问题, 一直处于研究状态, 没能来得及记录. 今天项目进度告一段落, 得以有空记录学习中遇到的一些问题. 由于MVC ...

  7. form表单和ajax表单提交(Html.BeginForm()、Ajax.BeginForm())的差别

    有如下几种区别: 1. Ajax在提交.请求.接收时,都是异步进行的,网页不需要刷新: Form提交则是新建一个页面,哪怕是提交给自己本身的页面,也是需要刷新的: 2. A在提交时,是在后台新建一个请 ...

  8. @using (Html.BeginForm()) @using (Ajax.BeginForm(new AjaxOptions() { })) 区别

    @using (Html.BeginForm()) 返回页面 也是页面 都是返回页面 只是 多了一个 data-ajax="true"

  9. 【转】利用Ajax.BeginForm提交文件

    Ajax.BeginForm @using (Ajax.BeginForm("YourAction", "YourController", new AjaxOp ...

随机推荐

  1. Javascript之对象的创建

    面向对象语言有一个非常显著的标志,那就是它们都有类的概念,通过类之间的继承就可以达到任意创建具有相同属性方法的对象.而在ECMAScript中并没有类的概念,它把对象定义为:无序属性的集合,其属性包含 ...

  2. ThinkPHP文件目录说明

    1.ThinkPHP文件包下目录结构说明 2.ThinkPHP文件目录下文件说明 3.Conf目录下 4.Library目录

  3. Effective STL 学习笔记 32 ~ 33

    Effective STL 学习笔记 32 ~ 33 */--> div.org-src-container { font-size: 85%; font-family: monospace; ...

  4. SonarQube的安装、配置与使用(windows)

    onarQube是管理代码质量一个开放平台,可以快速的定位代码中潜在的或者明显的错误,下面将会介绍一下这个工具的安装.配置以及使用. 准备工作: 1.jdk(不再介绍) 2.sonarqube:htt ...

  5. CVE-2013-2729 Adobe Reader和Acrobat 数字错误漏洞

    这个洞是在论坛里看到的,感觉很有意思,来学习一下.个人感觉IE或者说是浏览器的洞和Adobe洞都是比较难调的,主要是有大量的类难以摸清之间的关系. 这个洞是一个整数溢出的洞,这个不是重点.重点是利用的 ...

  6. WordPress用户登录后重定向到指定页面

    这篇文章将向您展示WordPress用户登录后如何重定向到指定页面或者文章的技巧. 一.重定向到网站管理面板. 将以下代码添加到您的当前主题的 functions.php 文件中: function  ...

  7. IntelliJ IDEA 显示行号

    设置方法如下:   File->Settings->Editor->Appearence->Show Line Number

  8. 【PAT】1018 锤子剪刀布 (20)(20 分)

    1018 锤子剪刀布 (20)(20 分) 大家应该都会玩“锤子剪刀布”的游戏:两人同时给出手势,胜负规则如图所示: 现给出两人的交锋记录,请统计双方的胜.平.负次数,并且给出双方分别出什么手势的胜算 ...

  9. Signalr信息推送

    前序 距离上次写文章,差不多已经大半年了.感觉自己越来越懒了,即使有时候空闲下来了,也不想动.前面买了一系列的Python的书,基础的看了大概有四分之一,剩下的基本上还未动,晚上回去也只是吃饭看电影. ...

  10. caffe 如何训练自己的数据图片

    申明:此教程加工于caffe 如何训练自己的数据图片 一.准备数据 有条件的同学,可以去imagenet的官网http://www.image-net.org/download-images,下载im ...