文章转自 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. android的单击监听事件

    Button button = (Button) findViewById(R.id.button1); //1.直接new出来 button.setOnClickListener(new View. ...

  2. .net 批量打印可实现方案

    最近几年一直在教育行业工作,主要负责竞赛类系统的开发工作,包括网上报名,安排考场,在线考试,学业报告书等. 打印功能在这个信息化时代非常普遍,浏览器都自带打印功能,通常的做法是调用 window.pr ...

  3. dp px 转换工具

    public class DensityUtil { private final static String TAG = "DensityUtil"; private static ...

  4. Android应用第一次安装成功点击“打开”后Home键切出应用后再点击桌面图标返回导致应用重启问题

    最近项目中遇到一个问题,用户第一次安装应用在系统的安装器安装完成界面有“完成”和“打开”两个按钮. 当用户点击“打开”按钮进入用户注册页面进行手机号验证码发送和验证码输入等操作界面,若此时用户点击Ho ...

  5. 第五章:Logistic回归

    本章内容 □sigmod函数和logistic回归分类器 □最优化理论初步□梯度下降最优化算法□数据中的缺失项处理 这会是激动人心的一章,因为我们将首次接触到最优化算法.仔细想想就会发现,其实我们日常 ...

  6. 「2014-2-8」Reading a blog on the pain points of Global Variables of C language

    晚上读到一篇<C 语言全局变量那些事儿>.我先前对链接的理解不深,算是涨了一番姿势.此文吐槽的重点,是「非 static 限定的全局变量」带来的看似出人意料(实则可以被合理解释)的行为.虽 ...

  7. #ing# CSS细节注意点

    目录: 常用简写 权重(优先级) Hack 常用简写 权重(优先级) Hack    etc

  8. poj 1061 青蛙的约会 拓展欧几里得模板

    // poj 1061 青蛙的约会 拓展欧几里得模板 // 注意进行exgcd时,保证a,b是正数,最后的答案如果是负数,要加上一个膜 #include <cstdio> #include ...

  9. 利用GBDT模型构造新特征

    [本文链接:http://www.cnblogs.com/breezedeus/p/4109480.html,转载请注明出处] 我的博客主营地迁至github,欢迎朋友们有空去看看:http://br ...

  10. jackson报错 无法解析,但是json一切正常

    因为类里面缺少无参构造(被有参构造盖掉了)