NVIDIA 初创加速计划,免费加速您的创业启动 了解详情
写点什么

为 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:012462
用户头像

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

关注

评论

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

✅对线面试官-单线程能不能实现多并发

派大星

面试突击 Java 面试题

马斯克称首位受试者可凭思维操控鼠标;字节低调推出视频模型丨 RTE 开发者日报 Vol.148

声网

【Java21问答】为什么synchronized会PINNED虚拟线程?

袁世超

synchronized ObjectMontior 虚拟线程 Java21

CORS就是跨域吗?

EquatorCoco

CORS web开发 跨域

已解决zipfile.BadZipFile: File is not a zip file异常的正确解决方法,亲测有效!!!

小明Java问道之路

LaunchPad 市场的复苏,Penpad 成新兴生力军

大瞿科技

OpenTiny Vue 组件库适配微前端可能遇到的4个问题

OpenTiny社区

开源 Vue 前端 微前端 组件库

ABCDE联合创始人BMAN确认出席Hack .Summit() 2024香港Web3盛会

TechubNews

香港Web3

LaunchPad 市场的复苏,Penpad 成新兴生力军

股市老人

论ai韭菜的自我修养

文思源想

AI 成长感悟 文思源想

Python 开发在未来会有怎样的发展?

算法的秘密

解锁Mysql中的JSON数据类型,怎一个爽字了得

不在线第一只蜗牛

json MySQL 数据库 开发语言

【论文解读】transformer小目标检测综述

合合技术团队

目标检测 Transformer 深度学习、

LaunchPad 市场的复苏,Penpad 成新兴生力军

加密眼界

什么是Ubuntu LTS?与常规版本的区别

百度搜索:蓝易云

云计算 Linux ubuntu 运维 云服务器

新一轮 LaunchPad 热潮形成的根源在哪里,Penpad或成机会

BlockChain先知

LaunchPad 市场的复苏,Penpad 成新兴生力军

股市老人

如何使用极狐GitLab 代码推送规则,提高代码质量?

极狐GitLab

你好,iLogtail 2.0!

阿里巴巴云原生

阿里云 云原生 iLogtail

基于规则引擎的多维度配置化适配系统

五陵散人

规则引擎 匹配

有少年气的手机,正奔跑在AI旷野

脑极体

AI手机

CQT新里程碑:SOC 2 数据安全认证通过,加强其人工智能支持

股市老人

深入剖析 Java 类属性与类方法的应用

小万哥

Java 程序人生 编程语言 软件工程 后端开发

解决centos离线安装cmake找不到OpenSSL问题

百度搜索:蓝易云

Linux centos 运维 云服务器 openssl

华为云帕鲁服务器-云耀云容器版,到底强在哪?

华为云开发者联盟

服务器 华为云 华为云开发者联盟 幻兽帕鲁

接手外包团队开发的微服务项目,人麻了!

伤感汤姆布利柏

LaunchPad 市场的复苏,Penpad 成新兴生力军

石头财经

已解决TypeError: Descriptors cannot not be created directly异常的正确解决方法,亲测有效!!!

小明Java问道之路

Mysql/etc/my.cnf参数详解

百度搜索:蓝易云

MySQL 云计算 Linux 运维 云服务器

华为云GaussDB支撑农行超级网银业务,性能和稳定性备受认可

华为云开发者联盟

数据库 后端 华为云 华为云GaussDB 华为云开发者联盟

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