Html.BeginForm() vs Ajax.BeginForm() in MVC3
我们知道,BeginForm()方法能创建一个Form标签,因此可以结合表单级的方法,在这个页面中。我一直在考虑Html.BeginForm()方法和Ajax.BeginForm()方法在MVC3中有什么不同。读了很多博客,很多人都强调了一件事:Ajax Form,Form被提交是使用了JavaScript异步提交的。
Html Form和 Ajax Form区别:
一,我做了一个简单的Demo来示范:
Step1:创建一个MVC项目
Step2:创建一个视图名为TestHtmlView.cshtml,此视图的Form表单使用Html.BeginForm()创建。此例子的操作是:当提交此表单时进行重定向;
- <span style="font-family:KaiTi_GB2312;font-size:18px;">@{
- ViewBag.Title = "Home Page";
- }
- <h2>@ViewBag.Message</h2>
- <p>
- @using(Html.BeginForm("TestHtmlRedirect", "Test",FormMethod.Post, null))
- {
- <input type="submit"value="Html PsBk Click" />
- }
- </p></span>
Step3:定义两个action方法,一个用于返回创建的视图,一个用于响应表单提交;
- <span style="font-family:KaiTi_GB2312;font-size:18px;"> //This section of code is forTestHtmlView.cshtml
- public ActionResult TestHtmlView()
- {
- ViewBag.Message = "HtmlForm——This is a HTML form";
- return View();
- }
- [HttpPost]
- public ActionResult TestHtmlRedirect()
- {
- returnRedirectToAction("TestAjaxView", "Test", null);
- }
- //End of the section of code forTestHtmlView.cshtml</span>
看一下TestHtmlRedirect()方法的实现体,我们想从该视图重定向到另一个视图TestAjaxView.cshtml。
Step4:创建一个视图名为AjaxHtmlView.cshtml,此视图的Form表单使用Ajax.BeginForm()创建。
- <span style="font-family:KaiTi_GB2312;font-size:18px;">@{
- ViewBag.Title = "Test Page";
- }
- <scriptsrcscriptsrc="@Url.Content("~/Scripts/jquery.unobtrusive-ajax.min.js")"type="text/javascript"></script>
- <h2>@ViewBag.Message</h2>
- <p>
- @using(Ajax.BeginForm("TestAjaxRedirect", "Test",FormMethod.Post, null))
- {
- <input type="submit"value="Ajax PsBk Click" />
- }
- </p></span>
Step5:如果想让此Ajax Form正确工作,能达到预期,那么还需要在AjaxHtmlView.cshtml中添加此JS文件引用
<scriptsrc="@Url.Content("~/Scripts/jquery.unobtrusive-ajax.min.js")"type="text/javascript"></script>
还要确保在Web.Config文件中支持JS的执行,需要此配置文件中添加如下标签:
- <span style="font-family:KaiTi_GB2312;font-size:18px;"> <!--启用客户端验证,Start。。。-->
- <addkeyaddkey="ClientValidationEnabled" value="true"/>
- <!--支持JavaScript的执行-->
- <addkeyaddkey="UnobtrusiveJavaScriptEnabled" value="true"/></span>
Step6:定义两个action方法,一个用于返回创建的视图,一个用于响应表单提交;
- <span style="font-family:KaiTi_GB2312;font-size:18px;">//This section ofcode is for TestAjaxView.cshtml
- public ActionResult TestAjaxView()
- {
- ViewBag.Message = "AjaxForm——This is a AJAX form";
- return View();
- }
- [HttpPost]
- public ActionResult TestAjaxRedirect()
- {
- returnRedirectToAction("About", "Test", null);
- }
- //End of Section of code forTestAjaxView.cshtml</span>
看一下TestAjaxRedirect()方法的实现体,我们想从该视图重定向到另一个视图About.cshtml。
(附录:
(1)About.cshtml:
- <span style="font-family:KaiTi_GB2312;font-size:18px;">@{
- ViewBag.Title = "关于我们";
- }
- <h2>关于</h2>
- <p>
- 将内容放置在此处。
- </p></span>
(2)Test控制器中添加About方法:
- <span style="font-family:KaiTi_GB2312;font-size:18px;">public ActionResult About() {
- return View();
- }</span>
(3)Global.asax
- <span style="font-family:KaiTi_GB2312;font-size:18px;">using System;
- usingSystem.Collections.Generic;
- using System.Linq;
- using System.Web;
- usingSystem.Web.Mvc;
- usingSystem.Web.Routing;
- namespaceComplaintManageSystem
- {
- // 注意: 有关启用 IIS6 或 IIS7 经典模式的说明,
- // 请访问 http://go.microsoft.com/?LinkId=9394801
- public class MvcApplication :System.Web.HttpApplication
- {
- public static voidRegisterGlobalFilters(GlobalFilterCollection filters)
- {
- filters.Add(newHandleErrorAttribute());
- }
- public static voidRegisterRoutes(RouteCollection routes)
- {
- routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
- routes.MapRoute(
- "Default", // 路由名称
- "{controller}/{action}/{id}", // 带有参数的 URL
- new { controller ="Test", action = "TestHtmlView", id =UrlParameter.Optional } // 参数默认值
- );
- }
- protected void Application_Start()
- {
- AreaRegistration.RegisterAllAreas();
- RegisterGlobalFilters(GlobalFilters.Filters);
- RegisterRoutes(RouteTable.Routes);
- }
- }
- }
- </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
- <span style="font-family:KaiTi_GB2312;font-size:18px;">using System;
- usingSystem.Collections.Generic;
- using System.Linq;
- using System.Text;
- usingSystem.Reflection;
- using Model.Adapter;
- namespaceModel.Entity
- {
- public class PersonnelModel
- {
- public string UserName { get; set; }
- public string MailAdress { get; set; }
- }
- }</span>
Step9:再分别定义Html和Ajax视图
HtmlViewModel.cshtml:
- <span style="font-family:KaiTi_GB2312;font-size:18px;">@modelHtmlVsAjaxBeginForm.Models.PersonnelModel
- @{
- ViewBag.Title ="HtmlViewModel";
- }
- <h2>HtmlViewModel</h2>
- @using (Html.BeginForm("HtmlViewModel","Home",null))
- {
- @Html.ValidationSummary(true)
- <fieldset>
- <legend>PersonnelModel</legend>
- <divclassdivclass="editor-label">
- @Html.LabelFor(model =>model.UserName)
- </div>
- <divclassdivclass="editor-field">
- @Html.EditorFor(model =>model.UserName)
- @Html.ValidationMessageFor(model => model.UserName)
- </div>
- <divclassdivclass="editor-label">
- @Html.LabelFor(model =>model.MailAdress)
- </div>
- <divclassdivclass="editor-field">
- @Html.EditorFor(model =>model.MailAdress)
- @Html.ValidationMessageFor(model => model.MailAdress)
- </div>
- </fieldset>
- <p>
- <input type="submit"value="Html Form Action" />
- </p>
- }</span>
AjaxViewModel.cshtml:
- <span style="font-family:KaiTi_GB2312;font-size:18px;">@model Model.Entity.PersonnelModel
- @{
- ViewBag.Title = "AjaxViewModel";
- }
- <script src="@Url.Content("~/Scripts/jquery.unobtrusive-ajax.min.js")" type="text/javascript"></script>
- <h2>AjaxViewModel</h2>
- @using (Ajax.BeginForm("AjaxViewModel", "Test", new AjaxOptions { UpdateTargetId = "result" }))
- {
- @Html.ValidationSummary(true)
- <fieldset>
- <legend>PersonnelModel</legend>
- <div id="result"></div>
- <div class="editor-label">
- @Html.LabelFor(model => model.UserName)
- </div>
- <div class="editor-field">
- @Html.EditorFor(model => model.UserName)
- @Html.ValidationMessageFor(model => model.UserName)
- </div>
- <div class="editor-label">
- @Html.LabelFor(model => model.MailAdress)
- </div>
- <div class="editor-field">
- @Html.EditorFor(model => model.MailAdress)
- @Html.ValidationMessageFor(model => model.MailAdress)
- </div>
- </fieldset>
- <p>
- <input type="submit" value="Ajax Form Action" />
- </p>
- }</span>
Step10:定义两个action方法,目的均为返回数据内容,显示在各自视图中
- <span style="font-family:KaiTi_GB2312;font-size:18px;">//HTML Form Method
- //Purpose: Will return the belowcontent, once after the method triggered.
- [HttpPost]
- public ActionResultHtmlViewModel(PersonnelModel Pmodel)
- {
- return Content("Hi" + Pmodel.UserName + ", Thanks for the details, a mail will be sentto " + Pmodel.MailAdress + " with all the login details.","text/html");
- }
- //AJAX Form Method
- //Purpose: Will return the belowcontent, once after the method triggered.
- [HttpPost]
- public ActionResultAjaxViewModel(PersonnelModel Pmodel)
- {
- return Content("Hi" + Pmodel.UserName + ", Thanks for the details, a mail will be sentto " + Pmodel.MailAdress + " with all the login details.","text/html");
- }</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的更多相关文章
- 爱上MVC3系列~Html.BeginForm与Ajax.BeginForm
Html.BeginForm与Ajax.BeginForm都是MVC架构中的表单元素,它们从字面上可以看到区别,即Html.BeginForm是普通的表单提交,而Ajax.BeginForm是支持异步 ...
- 转:MVC3系列:~Html.BeginForm与Ajax.BeginForm
Html.BeginForm与Ajax.BeginForm都是MVC架构中的表单元素,它们从字面上可以看到区别,即Html.BeginForm是普通的表单提交,而Ajax.BeginForm是支持异步 ...
- MVC3系列~Html.BeginForm与Ajax.BeginForm
Html.BeginForm与Ajax.BeginForm都是MVC架构中的表单元素,它们从字面上可以看到区别,即Html.BeginForm是普通的表单提交,而Ajax.BeginForm是支持异步 ...
- Html.BeginForm())与Ajax.BeginForm()
一.@using (Html.BeginForm())参数示例 1.指定表单提交方式和路径等 @using (Html.BeginForm("Index", "Home ...
- MVC小系列(十一)【Html.BeginForm与Ajax.BeginForm】
Html.BeginForm与Ajax.BeginForm都是mvc的表单元素,前者是普通的表单提交,而后者是支持异步的表单提交,直接用mvc自带的Ajax.BeginForm就可以很容易完成一个异步 ...
- MVC Html.BeginForm 与 Ajax.BeginForm 使用总结
最近采用一边工作一边学习的方式使用MVC5+EF6做一个Demo项目, 期间遇到不少问题, 一直处于研究状态, 没能来得及记录. 今天项目进度告一段落, 得以有空记录学习中遇到的一些问题. 由于MVC ...
- form表单和ajax表单提交(Html.BeginForm()、Ajax.BeginForm())的差别
有如下几种区别: 1. Ajax在提交.请求.接收时,都是异步进行的,网页不需要刷新: Form提交则是新建一个页面,哪怕是提交给自己本身的页面,也是需要刷新的: 2. A在提交时,是在后台新建一个请 ...
- @using (Html.BeginForm()) @using (Ajax.BeginForm(new AjaxOptions() { })) 区别
@using (Html.BeginForm()) 返回页面 也是页面 都是返回页面 只是 多了一个 data-ajax="true"
- 【转】利用Ajax.BeginForm提交文件
Ajax.BeginForm @using (Ajax.BeginForm("YourAction", "YourController", new AjaxOp ...
随机推荐
- Form 源码
1. is_valid如果返回值如果为真 证明验证成功 意味着self.is_bound为True 和 self.errors为False def is_valid(self): return sel ...
- opencv(5)GUI
OpenCV的图形用户界面(Graphical User Interface, GUI)和绘图等相关功能也是很有用的功能,无论是可视化,图像调试还是我们这节要实现的标注任务,都可以有所帮助. 窗口循环 ...
- opencv(1)图像处理
2.图像操作 图片裁剪 裁剪是利用array自身的下标截取实现 HSV空间 除了区域,图像本身的属性操作也非常多,比如可以通过HSV空间对色调和明暗进行调节.HSV空间是由美国的图形学专家A. R. ...
- web项目引入extjs小例子
一个新的项目,前端用extjs实现!分享一下extjs开发的准备工作! 首先去下载extjs的资源包,这里我是随便在网上下载的! 打开之后 ,目录是这样的! 需要关注的几个文件夹: builds:压缩 ...
- CentOS 6.5通过yum安装和配置MySQL
0x00 说明 Linux安装MySQL一共有两种方式,一种是下载安装包离线安装,另一种就是通过yum在线安装,这里先介绍在线安装的方式,此方法简单方便,出错最少,但是无法控制安装的MySQL版本,如 ...
- day4作业模拟实现一个ATM + 购物商城程序
作业需求: 模拟实现一个ATM + 购物商城程序 1.额度 15000或自定义: 2.实现购物商城,买东西加入 购物车,调用信用卡接口结账: 3.可以提现,手续费5%: 4.每月22号出账单,每月10 ...
- Web前端开发最佳实践(12):JavaScript代码中有大量写死的配置数据?这些数据难以维护,你需要合理组织这些数据
前言 JavaScript代码基本上都是由业务逻辑和数据组成的,逻辑代码根据数据完成一定的操作.很多数据在代码中是写死的,比如一些URL.显示在界面上的提示信息.页面元素相关的样式值及其他使用到的固定 ...
- MongoDB入门教程三[数据类型]
MongoDB的文档使用BSON(Binary JSON)来组织数据,BSON类似于JSON,JSON只是一种简单的表示数据的方式,只包含了6种数据类型(null.布尔.数字.字符串.数组及对象),不 ...
- ref:JAVA之Forward和Redirect的区别
ref:https://www.cnblogs.com/selene/p/4518246.html 阅读目录 一:间接请求转发(Redirect) 二:直接请求转发(Forward) 用户向服务器发送 ...
- 层级目录结构的Makefile递归编译方法
层级目录结构的Makefile编写方法. 层级目录结构的Makefile编写方法. 0.前言 1.如何编译整个工程 2.过滤每层不需要编译的目录 3将所有输出文件定向输出. 0.前言 假如现在有这样一 ...