写点什么

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

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

关注

评论

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

架构感悟 7- 性能优化何为

旭东(Frank)

秒懂云通信:选云通信到底哪家强?

阿里云Edge Plus

云通信 通信云

英特尔唐炯:竞争推动PC行业良性发展,促使英特尔前行

最新动态

BIGO | Likee深度推荐模型的特征工程优化

InfoQ_3597a20b53cc

人工智能

API网关——Kong实践分享

BoCloud博云

云计算 容器 PaaS API

第7周总结:性能

慵秋

为什么我们要自主开发一个稳定可靠的容器网络

BoCloud博云

云计算 容器 PaaS fabric

新手村:MySQL 学习经验、资源的分享

多选参数

MySQL MySQL 高可用 MySQL优化

【小白学YOLO】YOLOv3网络结构细致解析

华为云开发者联盟

人工智能 网络 物体检测 华为云 网络层

计算机网络基础(八)---网络层-路由概述

书旅

计算机网络 网络协议 计算机基础 AS

程序设计理念-CentOs7实践Nginx-带来安装服务的通用法则

图南日晟

nginx 架构设计 环境安装

架构训练营第七周作业

张锐

http请求压测工具

潜默闻雨

技术​选型的艺术

YourBatman

技术选型 湖北

为啥Underlay才是容器网络的最佳落地选择

BoCloud博云

云计算 容器

百度人脸算法“飞速迭代”,多模态活体检测V3.1获银行卡检测中心增强级认证

百度大脑

人工智能 人脸识别 百度大脑

web 性能压测工具

Z冰红茶

漫画:如何证明sleep不释放锁,而wait释放锁?

王磊

Java Wait Sleep

PV与UV你的网站也可以

北漂码农有话说

web压力性能测试

周冬辉

压力测试

前浪出新招,996已过时,互联网员工都开始住公司了!(爆公司信息)

程序员生活志

加班 996 007 互联网公司

原生Ingress灰度发布能力不够?我们是这么干的

BoCloud博云

云计算 容器 云原生 PaaS

进击的 Flink:网易云音乐实时数仓建设实践

Apache Flink

flink

直播中那几秒延时到底来自哪?

阿里云Edge Plus

CDN 云直播 直播 直播带货

数据湖应用解析:Spark on Elasticsearch一致性问题

华为云开发者联盟

大数据 spark elasticsearch 数据湖 华为云

挑战10的1,143,913次方种算法组合:这都不是事儿!

华为云开发者联盟

华为 算法 进化 华为云

Kubernetes的拐点助推器:左手开源,右手边缘计算

华为云开发者联盟

Kubernetes 容器 边缘计算 华为云

来了,来了,你们要的Nginx教程来了

Java旅途

nginx

第7周-作业1

seng man

关于数据库索引的知识点,你所需要了解的都在这儿了

鄙人薛某

MySQL 索引结构 索引 MySQL优化

百度大脑OCR技术助力钢铁物流实现智能管理

百度大脑

人工智能 百度大脑 文字识别

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