InfoQ

新闻

Lilu:Rails Mockup驱动开发之道

作者 Sebastien Auvray译者 高昂 发布于 2007年7月9日 上午12时0分

社区
Ruby
主题
设计,
Ruby on Rails
标签
Rails,
模板语言

在两年前就有过一场争论,争论的焦点在于Rails框架及它缺乏内建模板语言的支持,还有是否要为Rails引入这样的模板语言。直至今天,已经存在有不下五种的模板系统:ERB、 HAML、Liquid、Amrita2等等。然而所有这些都是将Ruby语言或是Ruby的派生语言与HTML代码混合在一起。Yurii Rashkovskii最近引入了一种新的模板系统,称为Lilu

Lilu是一种允许保持Rails视图不变,使其内部无须含有ERB标签侵扰的方法(和工具)。

Lilu的目标是让被插入在其中(按照Java中Tapestry的方式)的实际数据与HTML完全分离开,使保存并读取纯HTML代码更加容易。

Lilu保证你得到纯粹的HTML代码,并使你通过编写指令来使用实际数据更新代码。

Yurii Rashkovskii在挪威奥斯陆的Ruby Tuesday会议上进行了一次演讲,给出了如下的Lilu代码示例:

静态XHTML模仿app/views/blog/post.html

<ul id="found_users">
<li id="found_user">
<h1>John Doe</h1>
</li>
</ul>
<h4 id="no_matching_users">No matching users found</h4>

同时也给出对应的Lilu代码app/views/blog/post.lilu

if @users and !@users.empty?
populate('#found_user').for(:each,@users) do |user|
mapping 'h1' => user.name
end
remove('#no_matching_users')
else
remove('#found_users')
end

Rails创始人DHH对一个HTML和代码完全解耦的模板语言系统如何处像布局(layouts)和partils这样带来生产力的复杂技术持怀疑态度。但Lilu也提供对于partials的支持。

在RailsConf07大会上,Bruce William在主题演讲V is for Vexing中给出了Rails模板解决方案的介绍,以及优缺点分析。Lilu项目也应该被加入到列表之中。优点是Lilu将程序代码与HTML文档清晰的划分开来,允许通过HTML方便的与设计人员进行维护和协作。缺点有:1)与ERb相比性能稍逊,2)项目还处于早期状态,以及3)它不是Rails的标准之一。

两年前,David(即DHH)这样总结到:

对“无编码”模板的追求,让我想起MDA阵营对“无编码”程序这个圣杯的找寻。这是一种海市蜃楼式的幻想,也就是和“把玫瑰换个名字”(译注:原文是“a rose by any other name”,语出莎翁《罗密欧与朱丽叶》第二幕第二场的“A rose by any other name would smell as sweet.”朱生豪先生译为:“姓名本来是没有意义的;我们叫做玫瑰的这一种花,要是换了个名字,他的香味还是同样的芬芳。”)如出一辙的演出。

[...]

所以,如果你打算尝试一下这种方式,请自便。如果真的可能有一个完全非侵入性的(non-intrusive)解决方案出现,我将会认真思考是否要加入这样的特性。

现在有意思了:随着Lilu和Amrita2的到来,DHH这段话是不是还当真呢?

查看英文原文:Rails Mockup Driven Development with Lilu

2 条回复

回复

Blood Tie 发表人 Xiaogang Guo 发表于 2007年7月9日 上午11时33分
Re: Blood Tie 发表人 Jason Lai 发表于 2007年7月10日 上午1时12分
  1. 返回顶部

    Blood Tie

    2007年7月9日 上午11时33分 发表人 Xiaogang Guo

    Layout可以用类似SiteMesh Decorators的手法。完全解耦方便做AOP。Lilu看起来像是SiteMesh和Microformat生的娃。

  2. 返回顶部

    Re: Blood Tie

    2007年7月10日 上午1时12分 发表人 Jason Lai

    实际上 Lilu 更像 Tapestry:用对应的 HTML mock-up 作为模板,并在模板中进行更新点标记,然后在运行期用相应值更新模板中的更新点。

    我还没看它的源码,不过看样子像是把 HTML 模板解析成类似于 DOM 数的一个东西,然后进行更新。这样性能自然不佳,不过美工的生活就会更美好些了,直接可以用可视化设计器设计出带有演示数据的 mockup,无须另外做修改就可以用做模板。

独家内容

专访开源项目Amoeba架构师陈思儒

DBA notes站长冯大辉(Fenng)代表InfoQ中文站采访了分布式数据库Proxy开源项目Amoeba的架构师和主要开发者陈思儒,内容包括Amoeba项目的起因、功能及其愿景等。

使用JSF、Ajax和Seam开发Portlets(2/3)

作为三期系列文章的第二部分,本文延续了上一期内容,介绍了RichFaces,包括如何把RichFaces集成到之前提到的示例应用中、如何部署RichFaces porlet和RichFaces的多种特性和功能。

Jeff Barr谈论Amazon Web服务

Amazon Web Services(AWS)的传道者Jeff Barr讨论了SimpleDB、S3、EC2、SQS、云计算、Amazon的不同服务如何与应用交互、AWS的起源、SimpleDB和微软SQL Server Data Services、AWS cloud的全球化、三月份的AWS停机。

用Erlang实现领域特定语言

Erlang的并发模型很有名,它的健壮性也很有名。但其他方面呢?在这篇文章里,Dennis Byrne演示了如何用Erlang建立内部DSL。

基于Rails的企业级应用剖析

本视频主要以FreeWheel为例,对一个基于Rails的企业级应用进行了剖析。其中包括:FreeWheel的架构、部署、数据库的问题、REST API、敏捷开发过程、如何去写测试以及持续集成等等。

JavaFX技术预览

JavaFX显示了Sun的Java系列产品市场方向的一个重大转变。随着1.0版的即将发布,InfoQ以JavaFX预览版为参考,与Sun高级工程师Joshua Marinacci探讨了即将发布的1.0正式版。

剖析短迭代

敏捷教练Dave Nicolette提出:我们应该如何设定迭代长度?是要根据发布周期的时间么?使用短迭代又有哪些好处?

应用JSF、Ajax和Seam开发Portlets(1/3)

本文主要讲述了如何用JBoss Portlet Container 和JBoss Portlet Bridge创建新项目,怎样配置一个JSF应用去使用JBoss Portlet Bridge,以及JBoss Portlet Bridge所具备的功能。