InfoQ

新闻

SproutCore:将MVC引入JavaScript

作者 Shane Witbeck 译者 冉翔 发布于 2007年8月15日 下午10时52分

社区
Ruby,
Java
主题
Web框架
标签
AJAX

SproutIt发布了SproutCore,一个基于JavaScript语言的完整的全新MVC应用程序框架。SproutCore是SproutIt为了他们的产品Mailroom而开发的,现在已经被Apple用在了.Mac Web Gallery上。下面是来自Tucows的报导:

[……]SproutCore是一个完全运行于浏览器端的JavaScript框架,可以运行在以任何服务器技术为后端的配置环境中。在Jolley的公司SproutIt,他们使用Rails作为服务器后端,他们用一个包含了SproutCore框架的Rails插件来将一切变得更容易。Jolley说 Apple前端使用的是SproutCore,后台则使用WebObjects技术和一台WebDAV服务器[……]

由于市面上早就出现了不少Ajax程序库,InfoQ采访了作者Charles, Jolly,详细了解SproutCore与它们的不同之处。Jolly首先被问到究竟是什么灵感使得他在已有的很多JavaScript框架的之外还要再重新开发一个全新的框架:

在我们构建新版本的Mailroom(我们为小型商业公司提供的邮件管理器——http://www.sproutit.com/mailroom)时,我想做一些更加丰富多彩的东西,使其更像一个桌面软件,而不是一个Web应用程序。

但有个问题就是其它的框架都是被设计用来帮助你在网页的这儿或那儿添加一些Ajax以及动画效果,它们不能帮助你在Web浏览器之上构建一个功能齐备的应用程序。所以我在开发Mailroom的时候,所以我不得不额外构建的用来支持这个富界面的部分,都被我抽取出来,并在软件本身的基础上做出了这个框架。

他又回答了SproutCore所拥有的而其它现有框架没有的特性:

SproutCore和其它框架最大的不同之处在于,它为你提供了所有必要的工具,让你能真正得以与实际数据打交道。换句话说,你可以从服务器读取数据,然后用SproutCore来生成你的用户界面。同样,用户操作数据,SproutCore也将自动的更新你的用户界面并且不需要和服务器进行交互。它使得你的应用程序感觉非常的快速并且丰富多彩。

来看一个非常简单的例子:在Mailroom中我们有一个叫做“Needs Attention”的页面,来告诉你你现在必须回复的邮件。当你回复了一个信息,我们就马上将它从“Needs Attention”这个页面移除。

在传统的框架和Web程序中,你必须与服务器进行一次完整的交互或者编写大量额外的JavaScript。但是用SproutCore这一切都是自动的。只要将消息的状态设置为“已回复”,那么消息列表就会更新。

接下来Jolley被问到到底哪些应用程序该用SproutCore,哪些不该:

如果你希望构建一个更像桌面程序的富客户端程序,你一定要使用SproutCore。一旦你在页面上加入工具栏、菜单和源列表之类的组件后,你很快就会发现你得在页面上维护很多细微的状态。SproutCore使得这些变得更加容易实现。

如果你只是有个网页,并且只需要一些Ajax和动画特效的话,SproutCore就显得大材小用了。我倾向于使用一些更加简捷的框架,譬如 Scriptaculous。实际上,在我们的营销页面和Sproutit的Blog中,我们使用的是Scriptaculous和Prototype。不过我们也使用SproutCore来构建我们所有的Web程序。

随后,这次采访的话题又转向了Apple。Jolley谈到他自己和Apple之间在.Mac Galley上的合作。他说当Apple发现SpoutCore框架后,他被邀请加入他们的团队来帮助他们构建应用程序。为了提高SproutCore的性能以及完善它的API,.Mac团队为在原有基础上又添加了大量的功能。这就使得如今的SproutCore API的运行速度提高了4到5倍,同时跨浏览器方面的表现也是渐入佳境。

最后Jolley被问及了SproutCore的未来:

我正在为它加入更多的功能,例如源列表、工具栏、拖拽和一些超炫的动画效果,这将使SproutCore在UI设计方面更上一层楼。不过可能更重要的是,我正在构建一个实例性的应用或是一个入门教程,因为我认为这是现在采用SproutCore最重要的障碍。
查看英文原文:Bringing MVC to JavaScript - SproutCore
译者简介:冉翔,有着三年JavaEE工作经验,目前是一个Linux/RoR fan。北京RoR培训活动核心成员,个人网站ranxiang.com,你可以通过Email&Gtalk找到他:ranxiang(at)gmail.com。参与InfoQ中文站内容建设,请邮件至china-editorial[at]infoq.com

深度内容

和Google互补的搜索引擎Wolfram|Alpha

Wolfram|Alpha与Google究竟是什么关系,Wolfram|Alpha自己是如何定位的?Wolfram|Alaph在多大程度上是语义网搜索呢?InfoQ中文站就等等这些问题采访了Wolfram研究公司中国区商务经理王翔。

SOA契约成熟度模型

本文说明了所推荐的契约版本管理设计策略是如何与SOA成熟度模型发生联系的。文章目的是为实现版本管理和可组合性提供一个路线图。

数据服务简介

Vijay Narayanan在这篇文章中对数据服务的几个方面进行了介绍,它们都是SOA实践者和数据架构师感兴趣的内容。本文对数据服务的几个方面进行了介绍,包括需求定义,基本原理和好处、范围、开发以及消费模式。

分块云计算

在本文中,Jimmy Nilsson描述了一种他在过去数年间观察到的一种正在缓慢成长的架构风格,他把这种风格称为“分块云计算”。

豆瓣网技术架构变迁

罗马不是一天建成的,豆瓣的技术架构也是随着用户规模的增长一直在持续变化中。在本次演讲中,豆瓣的首席架构师洪强宁将与大家一起分享从上线时的单台服务器架构开始一直到现在的豆瓣架构变迁历程。

融合思想:深入探索S#arp架构

Billy McCafferty展示了S#arp架构,它在ASP.NET MVC框架的基础上,荟萃了当今的最佳实践,应用在ASP.NET Web应用程序的架构设计中。

王雷谈开源以及新兴市场计划

中国作为新兴市场中的新兴市场,是Sun在美国之外实施SSE(SUN Startup Essentials)项目重点关注的地区。在QCon Beijing 2009期间,InfoQ中文站有幸对此项目的负责人王雷先生进行了采访,探讨了关于开源、新兴市场、SSE等话题。

使用HTML5构建下一代的Web Form

HTML5 是由 WHATWG发起的,最开始的名称叫做Web Application 1.0,而后这个标准吸纳了Web Forms 2.0的标准,并一同被W3C组织所采用,合并成为下一代的HTML5标准。