文章转自 http://www.huiyoumi.wang/upload/forum.php?mod=viewthread&tid=75&extra=

Asp.net MVC 抛弃了Asp.net WebForm那种高度封装的控件,让我们跟底层的HTML有了更多的亲近。可以更自由、更灵活的去控制HTML的结构、样式和行为。而这点对于Ajax 的应有来说,Asp.net MVC确实要比WebForm优秀很多。我对Asp.net MVC更便捷的使用Ajax做了一下探讨,拿出来分享,欢迎拍砖。以下采用三种方式演示ajax的使用,两种都以简单demo展示希望大家多研究、提问和 分享经验。

第一、直接写JS代码实现Ajax:

因为Asp.net 浏览器端的代码能更好的控制,所以我们完全可以在HTML中直接通过JS发出Ajax请求,而在Controller的action中返回XML或者Json,来实现Ajax效果,这种方法是最原始的方法,需要考虑浏览器和诸多问题,不推荐使用。

参考代码如下:JS代码:

  1. var xhr;
  2.   function getXHR()
  3.   {
  4.   try {
  5.   xhr=new ActiveXObject("Msxml2.XMLHTTP");
  6.   } catch (e) {
  7.   try {
  8.   xhr=new ActiveXObject("Microsoft.XMLHTTP");
  9.   } catch (e) {
  10.   xhr=false;
  11.   }
  12.   }
  13.   if(!xhr&&typeof XMLHttpRequest!='undefined')
  14.   {
  15.   xhr=new XMLHttpRequest();
  16.   }
  17.   return xhr;
  18.   }
  19.   function openXHR(method,url,callback)
  20.   {
  21.   getXHR();
  22.   xhr.open(method,url);
  23.   xhr.onreadystatechange=function()
  24.   {
  25.   if(xhr.readyState!=4)return;
  26.   callback(xhr);
  27.   }
  28.   xhr.send(null);
  29.   }
  30.   function loadXML(method,url,callback)
  31.   {
  32.   getXHR();
  33.   xhr.open(method,url);
  34.   xhr.setRequestHeader("Content-Type","text/xml");
  35.   xhr.setRequestHeader("Content-Type","GBK");
  36.   xhr.onreadystatechange=function()
  37.   {
  38.   if(xhr.readyState!=4)return;
  39.   callback(xhr);
  40.   }
  41.   xhr.send(null);
  42.   }

复制代码

后台代码:

  1. public ActionResult GetNews(int CategoryID)
  2. {
  3. NewsCollectionModel newsCollection = new NewsCollectionModel();
  4. …………
  5. JsonResult myJsonResult = new JsonResult();
  6. myJsonResult = newsCollection;
  7. return myJsonResult;
  8. }

复制代码

第二种:使用Jquery进行Ajax调用:

在VS 2010中,IDE全面支持Jquery的智能显示,在开发中使用Jq来实现JS效果非常的棒,而且可以节省很多精力和时间。所以在Ajax中使用JQuery进行开发,也是一种不错的方法。

大概的实现代码如下:

  1. <% using (Html.BeginForm("AddComment","Comment",FormMethod.Post,new {@class="hijax"})) { %>
  2. <%= Html.TextArea("Comment", new{rows=5, cols=50}) %>
  3. <button type="submit">Add Comment</button>
  4. <span id="indicator"
    style="display:none"><img
    src="http://www.cnblogs.com/content/load.gif" alt="loading..."
    /></span>
  5. <% } %>
  6. 在View中引用Jquery:
  7. <script src="http://www.cnblogs.com/Scripts/jquery-1.4.1.min.js" type="text/javascript"></script>
  8. 添加下面脚本:
  9. <script type="text/javascript">
  10. //execute when the DOM has been loaded
  11. $(document).ready(function () {
  12. //wire up to the form submit event
  13. $("form.hijax").submit(function (event) {
  14. event.preventDefault();  //prevent the actual form post
  15. hijack(this, update_sessions, "html");
  16. });
  17. });
  18. function hijack(form, callback, format) {
  19. $("#indicator").show();
  20. $.ajax({
  21. url: form.action,
  22. type: form.method,
  23. dataType: format,
  24. data: $(form).serialize(),
  25. completed: $("#indicator").hide(),
  26. success: callback
  27. });
  28. }
  29. function update_sessions(result) {
  30. //clear the form
  31. $("form.hijax")[0].reset();
  32. $("#comments").append(result);
  33. }
  34. </script>

复制代码

第三种方法:使用微软自带的Ajax Helper框架来实现.

  1. <% using (Ajax.BeginForm("AddComment", new AjaxOptions
  2. {
  3. HttpMethod = "POST",
  4. UpdateTargetId = "comments",
  5. InsertionMode = InsertionMode.InsertAfter
  6. })) { %>
  7. <%= Html.TextArea("Comment", new{rows=5, cols=50}) %>
  8. <button type="submit">Add Comment</button>
  9. <% } %>

复制代码

第二种和第三种方法在博客园有篇博客中有所讲解,我直接进行了引用,具体地址如下:http://www.cnblogs.com/zhuqil/archive/2010/07/18/1780285.html

主要是对Ajax helper记录下我自己的看法和注意的事项。

第一、Ajax Helper是微软提供的一种Ajax框架,为了使用Ajax Helper必须使用微软提供的两个Js框架:

<script
src="http://www.cnblogs.com/Scripts/MicrosoftAjax.js"
type="text/javascript"></script>    <script
src="http://www.cnblogs.com/Scripts/MicrosoftMvcAjax.js"
type="text/javascript"></script>

第二、Ajax Helper有几个用法

Ajax.ActionLink():它将渲染成一个超链接的标签,类似于Html.ActionLink()。当它被点击之后,将获取新的内容并将它插入到HTML页面中。

Ajax.BeginForm():它将渲染成一个HTML的Form表单,类似于Html.BeginForm()。当它提交之后,将获取新的内容并将它插入到HTML页面中。

Ajax.RouteLink():Ajax.RouteLink()类似于Ajax.ActionLink()。不过它可以根据任意的routing参数生成URL,不必包含调用的action。使用最多的场景是自定义的IController,里面没有action。

Ajax.BeginRouteForm():同样Ajax.BeginRouteForm()类似于Ajax.BeginForm()。这个Ajax等同于Html.RouteLink()。

而每个方法里面的参数会有所不同,具体的用法见:http://msdn.microsoft.com/zh-cn/library/system.web.mvc.ajaxhelper_methods(v=VS.98).aspx

其中一个重要的参数为:AjaxOption,存在有以下几个属性,主要是来规定Ajax的行为的。

Asp.net MVC 中Ajax的使用 [分享]的更多相关文章

  1. ASP.NET MVC 学习笔记-7.自定义配置信息 ASP.NET MVC 学习笔记-6.异步控制器 ASP.NET MVC 学习笔记-5.Controller与View的数据传递 ASP.NET MVC 学习笔记-4.ASP.NET MVC中Ajax的应用 ASP.NET MVC 学习笔记-3.面向对象设计原则

    ASP.NET MVC 学习笔记-7.自定义配置信息   ASP.NET程序中的web.config文件中,在appSettings这个配置节中能够保存一些配置,比如, 1 <appSettin ...

  2. ASP.NET MVC 学习笔记-4.ASP.NET MVC中Ajax的应用

    Ajax的全名为:Asynchronous Javascript And XML(异步 JavaScript 和 XML),是指一种创建交互式网页应用的网页开发技术.Ajax技术首先向Web服务器发送 ...

  3. Asp.net MVC 中Ajax的使用

    Asp.net MVC 抛弃了Asp.net WebForm那种高度封装的控件,让我们跟底层的HTML有了更多的亲近.可以更自由.更灵活的去控制HTML的结构.样式和行为.而这点对于Ajax 的应有来 ...

  4. [转]Asp.net MVC 中Ajax的使用

    Asp.net MVC 抛弃了Asp.net WebForm那种高度封装的控件,让我们跟底层的HTML有了更多的亲近.可以更自由.更灵活的去控制HTML的结构.样式和行为.而这点对于Ajax的应有来说 ...

  5. Asp.net mvc中的Ajax处理

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

  6. ASP.NET MVC中使用ASP.NET AJAX异步访问WebService

    使用过ASP.NET AJAX的朋友都知道,怎么通过ASP.NET AJAX在客户端访问WebService,其实在ASP.NET MVC中使用ASP.NET AJAX异步访问WebService 也 ...

  7. Asp.net MVC Razor模板引擎技巧分享

    Razor是Asp.net MVC中新的默认模板类型, 语法简单易用.这篇文章不涉及Razor的语法,主要介绍Razor的一些在MVC项目中的使用技巧,以及脱离MVC环境下,如何使用Razor. 阅读 ...

  8. C# 动态生成word文档 [C#学习笔记3]关于Main(string[ ] args)中args命令行参数 实现DataTables搜索框查询结果高亮显示 二维码神器QRCoder Asp.net MVC 中 CodeFirst 开发模式实例

    C# 动态生成word文档 本文以一个简单的小例子,简述利用C#语言开发word表格相关的知识,仅供学习分享使用,如有不足之处,还请指正. 在工程中引用word的动态库 在项目中,点击项目名称右键-- ...

  9. ASP.NET MVC 实现 AJAX 跨域请求

    ASP.NET MVC 实现AJAX跨域请求的两种方法 和大家分享下Ajax 跨域的经验,之前也找了好多资料,但是都不行,后来看到个可行的修改了并测试下 果然OK了   希望对大家有所帮助! 通常发送 ...

随机推荐

  1. 如何用Matlab将cell数据写入文件

    我们知道,一般的文件读写函数是不接受直接将cell内容(非数值)直接写入文件的, 例如:dlmwrite('o.txt', C, 'delimiter', '\t');%C 为cell类型数据,会报错 ...

  2. 开启Python之路

    开始自学Python 环境配置 自己百度去!!! 计算与变量 字符创.列表.元组和字典 简单的画图 使用if和else条件控制语句 循环 使用函数和模块来重用代码 使用类和对象 Python内建函数的 ...

  3. UI基础

    知识点一:OC不允许直接修改对象的结构体属性的成员,允许直接修改对象的结构体属性 示例代码: CGRect tempFrame = self.frame; tempFrame.origin.x += ...

  4. 关于angular的一些新手容易忽略的小知识点

    1.解决页面刚加载时使用{{name}}这种方式绑定数据会有一瞬间的表达式显示的问题 方法一:  使用ng-bind来绑定数据, 方法二:  添加ng-cloak指令:如 <div ng-app ...

  5. backbone框架思路

    Backbone是MVC框架.如何使用这个框架来简化前端过程呢?作为一个初学者,虽然网上有它的官方文档,但是都是讲的一些方法,思路分析的却对初学者来说,看得晕乎乎的.现在就把自己对这个框架的理解记录在 ...

  6. React Native填坑之旅--Flow篇(番外)

    flow不是React Native必会的技能,但是作为正式的产品开发优势很有必要掌握的技能之一.所以,算是RN填坑之旅系列的番外篇. Flow是一个静态的检查类型检查工具,设计之初的目的就是为了可以 ...

  7. [LeetCode] 423 Reconstruct Original Digits from English

    Given a non-empty string containing an out-of-order English representation of digits 0-9, output the ...

  8. IIS服务的命令行方式重启命令

    打开IIS配置窗口的CMD命令:开始---运行---CMD----输入inetmgr 直接使用CMD我们可以操作很多事情,比如启动IIS,重启IIS,停止IIS 重启IIS服务器,开始->运行- ...

  9. JAVA/Android Map与String的转换方法

    在Android开发中 Map与String的转换在,在一些需求中经常用到,使用net.sf.json.JSONObject.fromObject可以方便的将string转为Map.但需要导入jar包 ...

  10. oracle中imp命令详解 .

    转自http://www.cnblogs.com/songdavid/articles/2435439.html oracle中imp命令详解 Oracle的导入实用程序(Import utility ...