架构妄想:AJAX + REST

  William Vambenepe的最新文章,AJAX + REST是最新的架构妄想,让我们回想起了一个具有15年历史的架构,它曾被寄期望对Web产生革命性的影响。

在该架构里,Web服务器将返回包含全部数据的XML文件,与XML一道,还会返回一个XSLT文件(用于描述如何将XML转换成HTML)。浏览器将依此处理XML数据,显示最终的HTML。搞定!该方式将带来很多好处,优于老式的“服务器生成HTML”模型。XML可以被其他应用方便地使用(不仅仅是人类),不同的XSLT可被用来将内容适配到各种客户端平台。

  光阴飞逝,但这种理念其实从未真正实现。现在,我们又快速地转向Ajax:

XML文档还在,尽管它通常被称为JSON。XSLT现在则是一大堆JavaScript。比起XSLT模型,这种模型有许多优势……它更灵活,可以实现小规模更新,以及部分页面刷新等等。但是,它是否也能够让架构保持清晰,使数据API与表现逻辑相分离呢?

  Vambenepe解释了原因,尽管它看上去优雅并包含了所有的架构优点,但该模型在大多数情况下并不实际:

相同服务的客户端支持多种交互模型,若不无限制的蔓延开来,单个API很难满足所有这些模型的需要(这里,所谓“单一API”,其实就是一块遮羞布)。但若是想让API保持外观简洁,你最终可能就会得到交互频繁的应用。

  但是在Vambenepe看来,这仅仅是该方法诸多问题中的一个。他指出的另一个大问题是该方法的事实:

……摒弃集成了浏览器代码和服务器代码的架构……不是所有Web开发者都认为他们的客户端框架和服务器框架是两套工具。将它们整体作为一个预先装配好的工具使用或许不会得到最优的代码,但可能还是可以最优利用你的开发资源。

  尽管Vambenepe有强有力的论据,他的帖子还是遭到了质疑。什么才是正确之路?为现有UI(如GWT风格)创建/生成单独的REST API?一方面,这种方法简化了UI实现;另一方面,每个UI都要有一个新API。这种方法的伸缩性更好吗?哪个代价更高?实现UI集成,还是后端API?由这个帖子还产生了另一个更严肃的问题:什么是正确的设计方法?先实现后端API,然后设计多个使用它的UI;还是开始从UI开始设计,然后再定义支撑它的API?传统来看,API实现的代价似乎更高,但API本身要比UI更稳定。

  因此,没错,满足各种需求的单一API看起来是架构妄想。但是,一组设计良好、轻巧可重用的API可被用来作为许多UI(Ajax)实现的基础。

  查看英文原文:Architectural Mirages

时间: 2024-10-18 03:45:25

架构妄想:AJAX + REST的相关文章

31、三层架构、AJAX+FormsAuthentication实现登陆

三层架构 前段时间公司要求修改一个网站,打开后我疯了,一层没有都是调用的DB接口,遍地的SQL语句,非常杂乱. 什么是三层架构? 三层架构是将整个项目划分为三个层次:表现层.业务逻辑层.数据访问层.目的为了高内聚低耦合思想. 三层结构 表现层(UI):接受用户请求,数据的返回呈现. 业务逻辑层(BLL ):用来处理业务逻辑,处理用户提交的数据. 数据访问层(DAL):用来与数据库进行交互,处理增.删.改.差. 实体类对象(Model):用来存储实体类. 三层关系 UI表现层:接收用户输入的数据,

Ajax提高篇(1)入门

学习目的:理解 Ajax 及其工作原理,构建网站的一种有效方法. Ajax 是 Asynchronous JavaScript and XML(以及 DHTML 等)的缩写. 下面是 Ajax 应用程序所用到的基本技术:? HTML 用于建立 Web 表单并确定应用程序其他部分使用的字段. ? JavaScript 代码是运行 Ajax 应用程序的核心代码,帮助改进与服务器应用程序的通信. ? DHTML 或 Dynamic HTML,用于动态更新表单.我们将使用 div.span 和其他动态

移动端开发者眼中的前端开发流程变迁与前后端分离

写在最开始 移动端与前端的区别 前端开发的混沌时代 后端 MVC MVC 方案实现 MVC 的缺点与改进 前端只写 Demo HTML 模板 后端 MVC 架构总结 AJAX 与前端 MVC 前后端分离的缺点 双端 MVC 不统一 SEO 性能不够 集中 Or 分离 Nodejs 前后端分离的哲学 Nodejs 分层 实战应用 风险控制 总结 参考资料 写在最开始 这是一篇面向移动端开发者的科普性文章,从前端开发的最初流程开始,结合示范代码,讨论开发流程的演变过程,希望能覆盖一部分前端开发技术栈

Vue 资源

一. 资源教程 综合类 vuejs 英文资料 Vue中文资料总汇 Vue.js 的一些资源索引 vue资料 入门类 vue 快速入门 Vue.js 中文系列视频教程 on Laravist 英文教程 Learning Vue 1.0: Step By Step 社区 sf - vue标签 知乎 - vue标签 Vue.js专业中文社区 vue - issues 二. 文档 API Vue.js - API router vue-router文档 三. 组件 1. 官方组件 Loader html

成都传智播客Java培训口碑做宣传

当今,信息技术日益成为现代组织实现创新和发展的重要手段,社会会对软件人才的需求持续增长,然而,一方面企业及组织聘不到合适的从业人员,另一方面又有众多的相关毕业生找不到合适的岗位.据此,成都传智播客特别推出了"Java开发工程师"培训班.欢迎有志从事且立足于软件业发展的学员报名参加本课程.我们期望这组课程将为您的职业生涯建立一个良好的开端和基础. [课程内容] 授课内容将结合目前业界主流的数据库系统.开发技术和环境分四个层次授课,第一个层次结合Oracle10i关系数据库管理系统讨论数据

Atitit.ati dwr的原理and设计 attilax 总结 java php 版本

Atitit.ati dwr的原理and设计 attilax 总结 java php 版本 1. dwr的优点相对于ajax来说.. 1 2. DWR工作原理 1 3. Dwr的架构 2 4. 自定义dwr还是native dwr 2 5. ApiHandler的标准化method 2 6. Invok..  Dwr.exe() 2 7. api.jsp 3 8. prj.Wxb distribu   api.jsp 3 9. ----------code 4 10. ApiHandler 4

16Aspx.com源码2014年7月详细

        Web电子商务网(三层)V2.0源码 2014-07-31   [VS2010] 源码介绍: Web电子商务网(三层)V2.0源码 源码描述: 一.源码特点     采用三层架构开发,购物车功能 二.功能介绍     前台集成了产品在线展示,用户注册.在线调查.在线投稿     后台有类别管理\图书管理\订单管理\会员管理\配送范围管理\邮件列表\广告管理\友情链接管理等     后台添加图书时自动生成缩略图和文字水印     主要参考了petshop的设计架构.使用了Asp.n

开始学习 Backbone

[转]开始学习 Backbone 如何将模型-视图-控制器 (MVC) 架构引入 Ajax Web 应用程序 如何高效管理 Web 应用程序中的数目众多的 JavaScript 代码行是一个挑战.Asynchronous JavaScript and XML (Ajax) 交互大量充斥着各种页面,为用户提供了更好体验.越来越普遍的单页界面均由 Ajax 驱动.Backbone 是一个 JavaScript 框架,可用于创建模型-视图-控制器 (model-view-controller, MVC

MVVM架构~knockoutjs系列之扩展ajax验证~验证输入数据是否与后台数据相等

返回目录 在看这篇文章之前,你有必要先看我之前的文章,之前文章是将一个方法以参数的形式传给KO,然后返回一个真假值,去做验证,这类似于面向对象语言里的委托,在JS里我们叫它回调方法,本篇文章与前一文章不同,需要有两个参数,其一是远程方法的签名(JS方法),其二是已知要比较的数据(可能是加密后的密码数据),当用户输入文字后,它将会调用JS方法获取远程数据,以比较原数据与你输入的数据是否匹配. 知识点:以对象作为参数进行传递 ko.validation.js的扩展 //ajax相等验证 kv.rul