2天时间,聊今年最热的 Agent、上下文工程、AI 产品创新等话题。2025 年最后一场~ 了解详情
写点什么

Cells:将组件开发带入 Rails 2.3

  • 2009-10-18
  • 本文字数:1873 字

    阅读完需:约 6 分钟

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

2009-10-18 21:041818
用户头像

发布了 90 篇内容, 共 38.9 次阅读, 收获喜欢 5 次。

关注

评论

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

【量化】股市技术分析利器之TA-Lib(一)

恒生LIGHT云社区

量化投资 量化

大规模 K8s 集群管理经验分享 · 上篇

尔达Erda

程序员 云原生 k8s K8s 多集群管理 经验分享、

云原生:详解|K8s核心对象技术

息之

k8s pod service Deployment

云原生:详解|容器核心技术解析

息之

Docker 镜像 技术优势

博文推荐|使用 Pulsar IO 打造流数据管道

Apache Pulsar

Java 开源 架构 云原生 Apache Pulsar

年末冲刺!坚持就是胜利,12月日更来啦~

InfoQ写作社区官方

12月日更 热门活动

Istio 实践手册 | 迎接新一代微服务架构

xcbeyond

istio 服务网格 28天写作 12月日更 Istio 实践手册

云原生:Docker实战之容器命令解析(附视频教程)

息之

Docker 视频课 解析

秒过!度目智慧通行让常态化防疫更高效

百度开发者中心

人工智能

《鱿鱼游戏》中的 AI 是绝对公平的吗?

澳鹏Appen

人工智能 人脸识别

区块链IM社交系统开发,区块链即时通讯直播系统搭建

电微13828808271

科技热点周刊|PHP 基金会成立、Rust 内讧、Amazon Linux 2022 预览版发布

青云技术社区

云计算

四步做好Code Review

百度开发者中心

Code Review

使用 @Transactional 时常犯的N种错误

程序猿DD

spring Spring Boot 事务

智慧社区服务平台搭建,智慧安防社区建设方案

电微13828808271

【量化】股市技术分析利器之TA-Lib(二)

恒生LIGHT云社区

量化投资 量化

如何设置Activity背景颜色与ProgressBar进度条颜色

Changing Lin

12月日更

架构实战营模块五作业

spark99

架构实战营

官宣!yMatrix 完成A轮融资,打造超融合时序数据库!

YMatrix 超融合数据库

「Spark从精通到重新入门(一)」Spark 中不可不知的动态优化

尔达Erda

云计算 大数据 spark 开发者 感悟

后端开发实战总结 | 签约计划第二季|后端

阿Q说代码

内容合集 签约计划第二季 技术专题合集

搭建企业级实时数据融合平台难吗?Tapdata + ES + MongoDB 就能搞定

tapdata

区块链应用食品溯源,为食品安全保驾护航

电微13828808271

WeTest小程序质量专项方案推出,小程序异常监控内测招募中

WeTest

贝壳Flutter调试工具-FDB

贝壳大前端技术团队

flutter 调试工具 内存监控

【有奖征文】第一届 OceanBase 技术征文大赛来啦!

OceanBase 数据库

数据库 开源 征文大赛 oceanbase

社区知识库|常见问答 FAQ 集合第 1 期

Apache Pulsar

Java 开源 Apache Pulsar 代码人生 社区

ZEGO 即构科技首发适配鸿蒙系统的 Express SDK 1.0 版本,并正式启动公测!(内附源码)

ZEGO即构

音视频 HarmonyOS 鸿蒙开发 即构科技

如何更快上手使用 OceanBase 社区版?

OceanBase 数据库

数据库 直播 课程 OceanBase 开源

Linux/CentOS/Ubuntu查看文件内容命令总结

入门小站

Linux

打造全新批流融合:详解 Apache Flink 1.14.0 发布的 Pulsar Flink Connector

Apache Pulsar

Java 大数据 分布式 云原生 Apache Pulsar

Cells:将组件开发带入Rails 2.3_Ruby_Mirko Stocker_InfoQ精选文章