写点什么

为 ASP.NET MVC 框架添加 AJAX 支持

  • 2007-12-31
  • 本文字数:1845 字

    阅读完需:约 6 分钟

ASP.NET MVC 框架的官方 CTP 版本还没有包括对 AJAX 的支持。不过目前有几个示例展示了如何为 ASP.NET MVC 应用添加 AJAX 功能。

Nikhil Kothari 提供了一个示例程序和示例代码,它们示范了为 ASP.NET MVC 框架添加类似 ASP.NET AJAX 这样的 AJAX 支持:

AjaxaController 是我添加的一个类,它引入了一个新的属性 IsAjaxRequest,我能够在 Action 方法中用它来做一些诸如输出不同视图的事情。它同样引入了另外一些成员,例如 RenderPartial 方法,它能够使用定义在一个部分视图中而不是一个完整页面中的内容,来生成用户界面的一部分。下面是我提供的新 Controller,以及新的 Add 方法。还有一些额外的改变用加粗来表示了:

<span>public</span> <span>class</span> TaskListController : <strong>AjaxController</strong> {<br></br><span>public</span> <span>void</span> Add(<span>string</span> name) {<br></br>  Task newTask = <span>null</span>;<br></br><span>if</span> (String.IsNullOrEmpty(name) == <span>false</span>) {<br></br>  newTask = _taskDB.AddTask(name); <br></br> } <br></br><strong><span>if</span> (IsAjaxRequest) {<br></br><span>if</span> (newTask != <span>null</span>) {<br></br> RenderPartial(<span>"TaskView"</span>, newTask);<br></br> }<br></br> }</strong> <span>else</span> {<p><span>[...]</span> }</p><br></br> } <br></br>}

除了 Controller 扩展之外,Nikhil 还提供了一些扩展方法给视图来使用:“RenderBeginForm 用于生成一个普通的 Form 标签,RenderBeginAjaxForm 生成一个 AJAX 可用的 Form […],以及 RendEndForm 方法”。这个示例“简单示范了使用 ASP.NET 页面中 AJAX 核心功能——部分刷新,Behaviors 和 Extender 控件——的第一步”

Kevin Hoffmann 在文章“如何为 ASP.NET MVC 框架提供 AJAX 功能”提出了他的看法。在一开始他批评 Nikhil 的示例仅仅示范了如何通过生成 HTML 来更新 Web 页面的一小部分。在他看来:

Ajax,在企业应用中,不仅仅是指动态生成一小块 div。诚然这的确是一个很重要的的部分,但是大部分人在使用 XMLHttpRequest 对象来向服务器端的 Controller 请求数据时,他们希望得到的仅仅是数据,而不是已经生成好的 div。在很多情况下,我们需要一个控制器通过不同的 Action(诸如 REST/POX/Web Services 类型的 Action)向智能客户端提供各种形式的数据。因此,尽管我在某些场景下会喜欢 RenderPartial 之类的方法,但是更好的例子应该是通过生成一个视图来输出简单的 XML,如果是 JSON 那就更好不过了。

它对 Controller 中提供的 IsAjaxRequest 属性更加担心:

MVC 最重要的就是合理的分离关注点。在示例中只有一行代码破坏了这一点,那就是IsAjaxRequest属性。这有点像设法让 MVC 框架变得和旧有的 PostBack 世界变得接近,而且坦白地说,旧有的 PostBack 世界能够解决我的问题。恕我直言,Controller 应该只是一个 Controller,它不应该,也不能决定应该是生成 AJAX 还是普通的内容,生成 AJAX 还是普通的 HTML 应该由 View 来决定。Controller 的作用应该是为生成一个视图获取正确的数据,然后选择一个试图进行内容生成。

Kevin 最后总结到,他希望微软能够提出一个令人信服的理由,来说明为什么开发人员不应该去使用一些其他的 AJAX 类库,使它们能够让 MVC 一起工作。

作为那些回应 Kevin 的人, Chad Myers 提供两个方法将其他的 AJAX 类库和 ASP.NET MVC 进行集成。在结合使用script.aculo.us 与ASP.NET MVC 框架一文中,Chad 展示了如何在ASP.NET MVC 视图中使用 script.aculo.us 客户端 JavaScript + AJAX 框架和它的一些控件。script.aculo.us 是“一套 Web 2.0 风格的 JavaScript 类库,可以帮助 Web 开发人员轻易为项目添加各种可视化和 AJAX 的效果”。

第二个方法展示了如何结合使用jQuery 和ASP.NET MVC 框架 jQuery 是“一个快速的,简练的 JavaScript 类库,能够简化您遍历 HTML 文档,操作事件,实现动画以及为您的 Web 页面添加 AJAX 交互效果”。Chad 将 Jack Born 实现“原地修改”效果的指南一文中说明的方法移植到了ASP.NET MVC 框架中,以此展示jQuery 能够如何方便地与新框架进行集成。用Chad 的话来说,如果您打算使用ASP.NET MVC 框架时,只需要将jQuery 示例中那些涉及服务器端部分里的“PHP”或“Ruby”等字样替换成“ASP.NET MVC”就可以了。

查看英文原文: Adding Ajax Support to the ASP.NET MVC Framework

2007-12-31 10:012542
用户头像

发布了 64 篇内容, 共 95788 次阅读, 收获喜欢 1 次。

关注

评论

发布
暂无评论
发现更多内容

区块链项目的商业模式有哪些成功案例

dappweb

区块链 ao

微创软件全资收购德国RLE NOVA GMBH公司与瑞士FINDERS SA公司

财见

在区块链中共识机制有哪些常见实现方式

dappweb

区块链 ao

区块链项目的商业模式

dappweb

区块链 ao

中之杰智能入选IDC报告,树立中国新型工业软件标杆

财见

蓝易云 - Ubuntu系统内核更新与卸载

百度搜索:蓝易云

云计算 Linux ubuntu 运维 云服务器

元宇宙与大数据

dappweb

ao 元宇宙

区块链可防止版权被篡改

dappweb

区块链 ao

拥抱鸿蒙生态,多彩宝加速政务服务数字化转型升级

最新动态

LeetCode题解:1669. 合并两个链表,JavaScript,详细注释

Lee Chen

区块链与DeFi在保险领域的创新应用

dappweb

区块链 ao

区块链供应链的透明度和可追溯性

dappweb

区块链 ao

元宇宙与增强现实(AR)

dappweb

ao 元宇宙

英特尔实现光学I/O芯粒的完全集成

E科讯

蜻蜓点金植入原生鸿蒙特性,助力金融服务更安全更便捷

最新动态

蓝易云 - centos用ssh登录连接缓慢处理

百度搜索:蓝易云

Linux centos 运维 SSH yum makecache

【XIAOJUSURVEY&北大】2024滴滴开源XIAOJUSURVEY北大软微开源实践课

XIAOJUSURVEY

开源 全栈 教育

区块链在保险数据共享中的挑战

dappweb

区块链 ao

混合共识机制中有哪些常见的设计挑战

dappweb

ao

供应链追溯的有效性和实时性

dappweb

ao

《机器学习与R语言》PDF

程序员李木子

拥抱鸿蒙生态,人民科技助推媒体融合发展和数字转型

最新动态

元宇宙与人工智能

dappweb

ao 元宇宙

监管合规下区块链保险数据共享如何实施

dappweb

区块链 ao

【XIAOJUSURVEY&北大】如何扩展设置器 - setters源码分析

XIAOJUSURVEY

前端 低代码 setters

蓝易云 - 香港好的云服务器提供商有哪些?

百度搜索:蓝易云

云计算 运维 云服务器 香港服务器 高防服务器

DeFi:重塑金融未来的去中心化浪潮

dappweb

ao

共识机制在区块链中起到什么作用

dappweb

区块链 ao

蓝易云 - 【redis问题】Caused by: io.netty.channel

百度搜索:蓝易云

redis 云计算 Linux 运维 云服务器

这个小游戏教你学好flex布局

大师兄

CSS JavaScript Flex

元宇宙与虚拟现实(VR)

dappweb

ao 元宇宙

为ASP.NET MVC框架添加AJAX支持_.NET_Hartmut Wilms_InfoQ精选文章