前言:前面我们已经简单的介绍过了MVC如何Jquery,因为我们如果使用Ajax的话必须要了解Jquery,这篇博客我们将大致了解一下ASP.NET MVC如何使用Ajax的辅助方法,此博客是我的读书笔记,如果那里写的不好,还请各位朋友提出来,我们共同学习。
1.准备工作
  (1)在MVC刚开始学习的时候,我们就需要介绍ASP.NET MVC框架中的HTML的辅助方法,但是这类文章现在已经很多了,而且个人感觉很简单,所以没有写笔记,我在这里就不介绍了。
  (2)ASP.NET MVC框架中的HTML辅助方法,我们可以使用HTML辅助方法创建表单和指向控制器操作的链接,在ASP.NET MVC框架中还包含一组Ajax辅助方法,它们也可以用来创建表单和指向控制器操作的连接,但不同的是它们是异步进行的,当使用这些辅助方法时,不用编写任何脚本代码来实现程序的异步性。
  (3)在后台,这些Ajax辅助方法依赖非侵入式MVC的Jquery扩展,如果使用这些辅助方法,就需要引入脚本文件jquery.unobtrusive-ajax.js,至于怎么引用我在上篇博客已经说过了,这里就不贴出代码了。
2.Ajax的ActionLink方法
  (1)在Razor视图中,AJAX辅助方法可以通过Ajax属性访问,和HTML辅助方法类似,Ajax属性上的大部分Ajax辅助方法都是扩展方法(除了AjaxHelper类型之外)。
  (2)Ajax属性的ActionLink方法可以创建一个具有异步行为的锚标签。现在我们可以在微软发布的MVC3.0的MusicStore项目上面进行修改,谁如果没有这个项目的话可以加地下的群,然后再群共享里面我共享了这个项目。在视图”Views/Home/Index.cshtml”中添加下面的代码。

1 <div id="dailydeal">
2     @Ajax.ActionLink("点击我", "DailyDeal", new AjaxOptions
3     {
4       UpdateTargetId="dailydeal",
5       InsertionMode = InsertionMode.Replace,
6       HttpMethod="Get"
7     })
8 </div>

  (3)ActionLink方法的第一个参数指定了连接文本,第二个参数是要异步调用的操作的名称,类似于同名的HTML辅助方法。对于HTML辅助方法和Ajax辅助方法,显著不同的是AjaxOptions参数,该参数指定了发送请求和处理服务器返回结果的方法,参数中还包括用来处理错误,显示加载元素,显示确认对话框等的选项。为了得到服务器的响应,需要在控制器HomeController上添加一个DailyDeal操作,代码如下:

1      public ActionResult DailyDeal()
2   {
3     var album = GetDailyDeal();
4     return PartialView("_DailyDeal", album);
5   }
6   private Album GetDailyDeal()
7   {
8     return storeDB.Albums.OrderBy(a => a.Price).First();
9   }

  (4)Ajax操作连接的目标操作的返回值是纯文本或HTML。下面的Razor代码就在项目的Views/Home文件夹下的_DailyDeal.cshtml文件中。
  
  注解:Ajax.ActionLink生成的内容能够获得服务器的响应,并可以直接将新内容移植到页面中,这时为什么呢?下面我们就介绍一下异步操作连接的工作原理。
3.HTML5特性
  (1)如果我们查看ActionLink方法渲染的标记,我们会看到如下代码:
    <a data-ajax="true" data-ajax-method="Get" data-ajax-mode="replace" data-ajax-update="#dailydeal" href="/Home/DailyDeal">点击我</a>
  (2)非侵入式JavaScript的显著特点就是在HTML中不包含任何JavaScript代码,也就是说在HTML中看不到脚本代码,如果仔细看的话就会发现ActionLink中指定的所有设置被编码成了HTML元素的特性,并且这些编码的大多数特性都有data-前缀,通常称之为data-特性。
  (3)HTML 5规范为私有应用程序保留了data-特性,换句话说,web浏览器不会尝试解释data-特性的内容,因此可以放心的把自己的数据交给它,这些数据不会影响页面的显示或者渲染。
  (4)向应用程序中添加jquery.unobtrusive-ajax文件的目的是查找特定的data-特性,然后操纵元素使其表现出不同的行为。
  (5)所有的ASP.NET MVC AJAX特性都使用data-特性。
4.Ajax表单
  (1)下面我们实现另外一种情形,要在音乐商店的首页为用户添加一个查找艺术家的功能,因为需要用户的输入,所以必须在页面上面放一个form标签,但这不是一个普通的标签,而是一个异步表单。下面这段代码我们看一下:
  

 1 @using (Ajax.BeginForm("ArtistSearch", "Home", new AjaxOptions
 2   {
 3     InsertionMode = InsertionMode.Replace,
 4     HttpMethod = "GET",
 5     OnFailure = "searchFailed",
 6     LoadingElementId = "ajax-loader",
 7     UpdateTargetId = "searchresults",
 8   }))
 9   {
10     <input type="text" name="q" />
11     <input type="submit" value="Search" />
12     <img id="ajax-loader" src="@Url.Content("~/Content/Images/ajax-loader.gif")" style="display:none" />
13   }

  (2)再要渲染的表单中,当用户单击提交按钮时,浏览器就会向控制器HomeController的ArtistSearch操作发送异步GET请求,注意上面的代码已经指定了LoadingElementId作为其中的一个选项,当执行异步请求时,客户端框架会自动的显示这个元素,通常情况下,在这个元素内部会出现一个具有动画效果的微调框,来告知用户后台正在进行一些处理,此外,还有一个OnFailure选项,这些选项包括许多参数,可以设置它们以捕获来自Ajax请求的各种客户端事件,如OnBegin,OnComplete,OnSuccess和OnFailure等,可以给这些参数赋予一个JavaScript函数的名称,当事件触发时,调用该函数,上面的代码就为OnFailure指定了一个JavaScript函数,代码如下:
  <script type="text/javascript">
    function searchFailed() {
      $("#searchresults").html("对不起,查询有问题");
    }
  </script>
  (3)如果服务器代码返回一个错误,就意味着AJAX辅助方法都执行失败了,此时,你可能想捕获OnFailure事件,如果用户单击”search”按钮而页面没有反应,我们可能就会感到困惑,跟前面代码所做的一样,可以显示一个错误提示信息,至少让他们知道我们已经尽力了。
  (4)辅助方法BeginForm的输出类似于辅助方法ActionLink,最后,当用户单击提交按钮提交表单的时候,服务器会接受到一个Ajax请求,并可能以任意格式的内容作出响应,当客户端收到来自服务器端的响应时,非侵入式脚本就会将相应的内容放入Dom中。
  (5)对于这个例子,控制器操作需要查询数据库并且渲染一个分部视图,此外,操作还要返回纯文本,但同时又想把艺术家放到一个列表中,因此,在HomeControler中写入如下的方法代码:

 1  public ActionResult ArtistSearch(string q)
 2   {
 3     var artists = GetArtists(q);
 4     return PartialView(artists);
 5   }
 6
 7   private List<Artist> GetArtists(string q)
 8   {
 9     return storeDB.Artists.Where(a => a.Name.Contains(q)).ToList();
10   }

  (6)该分部视图利用模型构建列表,它位于项目的Views/Home文件夹下的视图ArtistSearch.cshtml。

 1 @model IEnumerable<MvcMusicStore.Models.Artist>
 2   @{
 3     Layout = null;
 4   }
 5   <!DOCTYPE html>
 6   <html>
 7     <head>
 8     <title>ArtistSearch</title>
 9     </head>
10     <body>
11       <div id="searchresults">
12         <ul>
13           @foreach (var item in Model)
14             {
15               <li>@item.Name</li>
16             }
17         </ul>
18       </div>
19     </body>
20   </html>

5.web.config文件里的AJAX设置
  (1)默认情况下,非侵入式JavaScript和客户端验证在ASP.NET MVC应用程序中是启用的,然后,我们可以通过web.config文件中的设置改变这些行为,如果打开新应用程序根目录下的web.config文件,就会看到下面的appSettings配置节点:
  <appSettings>
    <add key="webpages:Version" value="1.0.0.0"/>
    <add key="ClientValidationEnabled" value="true"/>
    <add key="UnobtrusiveJavaScriptEnabled" value="true"/>
  </appSettings>
  (2)如果想在整个应用程序中禁用这两个特性中的任意特性,只需要将响应特性的value值修改为false即可,另外,还可以逐视图是的控制这些设置,HTML辅助方法EnableClientValidation和EnableUnobtrusiveJavaScript在一个具体视图中重写了这些配置设置。
  (3)由于现有的自定义脚本都是依赖与Microsoft AJAX库而不是Jquery库,因此禁用这些特性的主要原因是维护应用程序的向后兼容性。

  注:下篇MVC的博客我们将把注意力转向ASP.NET MVC框架的另外一个内置AJAX特性-对客户端验证的支持。

    相信自己,你就是下一个奇迹!

ASP.NET MVC如何使用Ajax的辅助方法相关推荐

  1. ASP.NET MVC中使用AJAX(XMLHttpRequest、Microsoft AJAX Library......)

    AJAX的好处就是不会堵塞页面,可以提高用户体验,可以减少数据传输尺寸,提高应用程序的性能.目前,AJAX技术可以说是已经成为WEB开发的标准技术. AJAX技术是纯客户端技术,任何客户端框架(如:M ...

  2. 在ASP.NET MVC 模型中 选择最好的方法将多个model(数据模型)传递到视图

    在ASP.NET MVC 模型中 选择最好的方法将多个model(数据模型)传递到视图 前提介绍 这个文章我们要讨论,在ASP.NET MVC模型的项目中,怎么选择一个最有效的方式来将多个数据模型(m ...

  3. 精通ASP.NET MVC ——URL和Ajax辅助器方法

    Ajax(或者,如果你愿意,也可以称为AJAX)是 Asynchronous JavaScripts and XML(异步JavaScripts与XML).其XML部分并不如它往常那样意义重大,但是异 ...

  4. asp.net ajax删除数据,Asp.net MVC 2 使用Ajax删除数据

    一.新建一个Asp.net MVC 2 Empty Web Application. 二.添加一个名叫DataClasses1.dbml的Model,拖放Student表,最后如下图所示. 三.添加一 ...

  5. Asp.net mvc中的Ajax处理

    在Asp.net MVC中的使用Ajax, 可以使用通用的Jquery提供的ajax方法,也可以使用MVC中的AjaxHelper. 这篇文章不对具体如何使用做详细说明,只对于在使用Ajax中的一些需 ...

  6. C#最全最详细Nancy框架学习(常见报错,控制台应用,添加到现有ASP.Net MVC站点,ajax)

    这篇博客能解决大家70%的Nancy问题 例2源码下载:https://download.csdn.net/download/qq_37791451/10678639 最近学习了Nancy框架,踩过了 ...

  7. ASP.net MVC自定义错误处理页面的方法

    在ASP.NET MVC中,我们可以使用HandleErrorAttribute特性来具体指定如何处理Action抛出的异常.只要某个Action设置了HandleErrorAttribute特性,那 ...

  8. 关于ASP.NET MVC P5中CheckBox的HtmlHelper方法的bug。

    在ASP.NET MVC P5中,当你使用这样的方法输出CheckBox:<%=Html.CheckBox("checkTest")%>,在浏览器上除了你期望看到的代码 ...

  9. Asp.Net MVC 关于npoi导出excel的方法

    导出的excel的是一个项目的基本功能    所以不多说  我们项目用的npoi     可以直接在vs的NuGet里面直接搜索下载 安装就可以用了 //创建一个excelHSSFWorkbook h ...

最新文章

  1. vijos - P1279Leave-绿光(数学归纳法 + python)
  2. 手把手带你打造一款 签名设计 的GUI图形界面!
  3. GitHub的AI写代码翻车了,会在注释里给你写上what the f***,因为...
  4. PostgreSQL_row_number() over()_应用实例
  5. 向模拟器发短信打电话的方法
  6. iOS之深入解析KVO的底层原理
  7. P4语言编程快速开始 实践二
  8. iOS学习 NSString常用技巧
  9. 使用docker部署mysql主从复制集群
  10. 如何查看linux 日志 磁盘使用情况?
  11. qgis oracle,用 QGIS 画矢量交通路线图
  12. python // 运算符
  13. oracle回退脚本怎么写_短视频爆款文案怎么写?130个短视频爆款文案、脚本范例分享!...
  14. Istio Proxy【Envoy扩展】详解
  15. numpy.loadtxt() 用法
  16. 微服务调用组件Ribbon底层调用流程分析
  17. 计算机应用技术专业与计算机网络技术专业的区别
  18. codesys file读写配置参数程序
  19. 未来房价涨or跌?大数据告诉你
  20. 官宣 .NET RC 2

热门文章

  1. python读取二进制数据转整形,在python中读取二进制数据(替换C代码)
  2. java 赋值md5_Hook Java API以获得MD5加密前数据
  3. python 抽象类和接口
  4. 编程通用知识 乘法除法位移
  5. numpy reshape
  6. flask-sqlalchemy 数据基本操作--实例
  7. CentOS7添加自定义系统服务
  8. explain的用法_这次是真拯救了我,MySQL索引优化,explain讲得非常清楚了
  9. 大V诞生记 —— 谁是VMware?
  10. NetScaler SDWAN 的前世今生