文章转自 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. IE8的兼容性问题

    IE的兼容性问题是前端开发人员的老大难问题,不过随着时代的发展,IE6逐渐的被淘汰,现在以及很少有网站兼容IE6了,一般都兼容到IE8,现在我总结了一些IE8的兼容性问题及解决方法. 1.使用meta ...

  2. 数据导出Excel中文乱码

    数据导出到EXCEL提供用户下载,当记录数大于5行时不会出现乱码.但只要不退出Excel,再删除除记录,当记录数小于5行时,导出也不会出现乱码.当然一旦退出Excel再导出就会出现乱码了. 可以试试 ...

  3. 实现js的二叉树

    今天算是第一次写一篇自己的博客,越是学习就越感叹学无止境,为了记录下来用js实现二叉树的方法,这算是最简单的一个算法了. 二叉树实现原理:把数组的第一个数据当作根节点,每个节点都有根节点,左孩子和右孩 ...

  4. 第十二章:使用FP-growth算法进行关联分析

  5. js call apply

    参考文章:https://www.zhihu.com/question/20289071 引用:call 和 apply 都是为了改变某个函数运行时的 context 即上下文而存在的,换句话说,就是 ...

  6. .net之微信企业号开发(二) 企业号人员身份认证与开发

    前言 这里完全可以链接一个登录页面,让用户输入用户名密码进行登录的...2333 但是,这样所就完全失去了微信企业号的意义,本来进入微信企业号的时候,就已经对人员身份进行认证了,你这里再让别人登录,不 ...

  7. arduino 入手

    新买了个ardhuino 入门套件 1. Win7 Driver issue: Need to install the below drivers, because my windows is ins ...

  8. ubuntu安装erlang

    照着园子里一篇博文安装erlang,各种错调不出来.最后发现官网有解决方案: https://www.erlang-solutions.com/downloads/download-erlang-ot ...

  9. 无法远程到2008R2的解决方法

    运维的一台Server,昨天还很正常,今天突然远程桌面无法登陆,提示“由于没有远程桌面授权服务器可以提供许可证,远程会话被中断.....”,开始以为是权限问题,试了很多方法,都无法解决,后来上网找解决 ...

  10. linux定时执行任务crontab命令用法

    linux系统的定时任务是由 cron (crond) 这个系统服务来控制的.Linux 系统上面原本就有非常多的计划性工作,因此这个系统服务是默认启动的.另外, 由于使用者自己也可以设置计划任务,所 ...