Cells:将组件开发带入 Rails 2.3

  • Mirko Stocker
  • 杨晨

2009 年 10 月 18 日

话题:RubyWeb框架Ruby on Rails语言 & 开发

Cells"将使得面向组件的开发惠及 Ruby on Rails Web 应用平台“,使得你能够创建独立并且可以重用的组件,这些组件是自包含的,并且能够和应用程序中的其他 Cells 组合在一起或者被其他 Cells 重用。

构建在 Cells 之上的Apotomo对 Cells 进行了改进,使其成为一个完全状态化的组件,能够提供和广为人知的 GUI widget 同级的抽象能力,即“Apotomo 使用能够自升级的事件驱动的 widget 扩展了 Rails 的功能”。所以,使用 Apotomo 的开发者能够利用现有的 JavaScript UI 库,例如 YUI,而不需要编写 JavaScript 代码或者关心底层 AJAX 调用。Apotomo widget 能够形成事件链,使得 widget 能够独立于其他并且易于重用。

InfoQ 已经关注 Cells 达一年之久,与此同时,Cells 1.0 已经发布,并且 Apotomo 的工作仍在继续。

InfoQ 采访了 Cells 的主要开发者 Nick Scutter。当问到“自从上次见面过后,这一年来你们对 Cells 进行了哪些改进呢?”,他回答道:

非常多!Cells 和 Rails 从 1.2.3 一起成长到 2.3,我也学习了 Ruby!我对语言的良好理解能力,以及大量整洁和结构化的 Cells 代码帮助了我。

除了我们介绍的高易读性的代码,我们还介绍了一种简单的,类似于 Rails 视图中使用的碎片缓存的缓存技术。这个技术允许缓存 Cells 视图,直到一个加载的版本更新方法决定其已经过期,而不会使得一个 Cell 实例失去其面向对象的特性。Michal Lomnicki 提供了非常多的帮助,他在他的项目中使用了补丁以及真实的测试用例。

上次你说在 Rails 社区有一个“值得注意的趋势”。现在情况是怎么样了?

我不会在这里说一些统计数据。好吧,当我开始 Cells 的时候,很多程序员都对我谈起过 Rails 缺少组件这个问题。

看看 GitHub 中 Cells 的监视器就能够明白,我们现在有大约 150 个代码编写者,他们能够在 Cells 被改动的第一时间得到通知。这很酷啊,我喜欢开发者对 Cells 感兴趣。我们有 6 个成功的分支合并到主线上。

突然网上出现了一些博客文章,讨论 Cells 和它的变种,例如部分和 presenter 结合起来,了解他人的想法是一天非常激动的事情。

另外一个激动的事情是 IRC 的 #cell 频道。每次我加入的时候,总有 4 到 8 个人在潜水,他们来自于世界上各个地方。而新人不断地涌进然后寻求帮助。我想这个频道是这个项目中最重要的支持媒介,在这里遇到朋友总是非常有意思的。

自从 Cells 的发布开始,大量的公司告诉我他们在实际项目中使用 Cells 的情况。即使有 IBM 的资助,我仍然对等待其他人捐赠这事有点失望,真该感谢 MIT license。

这个项目值得留恋的是和我兄弟 Mike Pence 在 Florida 的 Orlando 举办的RubyConf 2008的谈话。我们在 Sarasota 度过了一段美妙的时光,准备讨论,喝啤酒和狂欢!有很多人坐在大堂中倾听我们的演讲。我们在演讲之后进行了非常深入的讨论,即便在晚会上,我们也没有停止交谈。

在我们美国之行之后,我们发布了 Cells for Rails 2.3,在 Apotomo 博客上发布的官方信息每天的浏览数都在 500 左右。这是一个非常愉快的经历,也证明了 David 的眼光没错。

David 曾经和我们联系过,但是我们从没有想过找一个如何将 Cells 集成到 Ruby 中的方案。我们更愿意它是一个插件。插件是好东西。

我曾经研究过 Rails 3 的代码。我也是 Yehuda 重构的粉丝,我真心希望一个新的内嵌 API 能够帮助它实现一些 Cells 的功能。每个人都需要组件。所以,我希望等待,直到 Rails 3 的 API 稳定,或者我可以继续钻研 Cells。现在,我主要在编写教程,文章以及改进 Apotomo,我们可以期待一下在 Rails 3 中使用的 Cells 吧。

我们真的需要状态化的组件吗?

不,如果你喜欢“暴力线性控制流”,在每一个请求,你要么展现完整的页面,或者在控制器,视图甚至在你 MVC 栈的模型中有一些凌乱的 AJAX 逻辑,那么你不需要组建。同样,如果你希望对每个请求建立完整的处理环境,那么你也不需要状态化。

让我们引用 Mike 的话。“现在是拥有一个更好的玩具的时候了,虽然这些孩子已经有很好的玩具,但是为什么不将 Rails 更进一步呢”。Smalltalk 开发者喜欢 Seaside,GUI 开发者讨厌 Web。为什么不把这些东西的优点结合起来放入 Rails 中呢?

我的意思是,在其应用中使用多少 Apotomo 完全取决于程序员本身,当他体验过状态化 widget 的巨大威力之后,他不会再回到他的臃肿的控制器了。

不仅仅是其重用性,而且还有它良好的封装,为程序准备的强力测试器,它是事件驱动的,只需要很少的代码以及一个优秀的开发流就能够得到一个状态化的 widget,它真酷。

请访问 RubyForge 上的Cells网站获取更多信息。

查看英文原文:Cells: Components for Rails 2.3

RubyWeb框架Ruby on Rails语言 & 开发