Revolutionary Template Tech -- fastm

原创 2005年05月30日 17:37:00

Revolutionary Template Tech -- fastm

1. Overview

There are a lot of template techs on the world, like JSP, Taglib, Freemarker, Velocity, XSL, Jivan, XMLC, Tapestry, Wicket, JDynamiTe, etc.

For more info, please visit.

http://java-source.net/open-source/template-engines

 

The reason why I write “yet another template -- fastm” is just that I can not find a good enough one for me to use.

 

The templates fall into 2 categories:

(1) Script with logic (if, else, for); like JSP, Taglib, Freemarker, Velocity, XSL, Tapestry, etc.

(2) Resource without logic; like Jivan, XMLC, Wicket, fastm, etc.

Here I like to review these templates group by group to list their and disadvantages that I am not satisfied.

2. JSP, Taglib

At first, people write HTML in the Servlet code. The code is polluted by the long HTML.

So JSP is made.  Then people write code in the HTML.  The HTML is polluted by code.

So Taglib is made. People write Taglib as code, since Taglib’s XML format seems look better than code in the HTML.

To display the Taglib in HTML Editors like Dreamweaver, Taglib Display Plugin is made. They are complex jobs.

As we can see, the whole thing is becoming more and more complex.

3. Freemarker, Velocity

Freemarker, Velocty are scripts containing logic like if, else, for, set, etc, which may affect the HTML display effect in the HTML browser.

4. Tapestry, Wicket

Tapestry, Wicket uses HTML tag as its logic tag or page component tag.

Tapestry contains logic like if, else, for, etc, while Wicket contains none.

Both Tapestry and Wicket have their own view model like Label, Link, Table, etc.

You have to write code to put your data into these view models.

5. Jivan, XMLC

www.jivan.org

Jivan and XMLC directly manipulate the HTML DOM node. Pure HTML, no any pollution.

You have to write code to put your data into the DOM node.

6. XSL

XSL directly manipulates the HTML DOM node too.

XSL can be seen as a little complex template script containing logic like match, choose, otherwise, etc.

7. JDynamiTe

http://sourceforge.net/projects/jdynamite

JDynamiTe ports PHPBB template to Java.

Like PHPBB template, you have to write code to search the resource block in the template and then use it.

To solve that problem, I wrote fastm.

8. fastm

Now it is fastm’s turn. Thanks for your patience. :-)

fastm tries to avoid above disadvantages and leverage their advantages.

fastm template is like PHPBB or JDynamiTe template, which uses XML comment as block mark and not contains any logic at all.

 

The formula of fastm is very simple and straight-forward:

Template DOM + Object DOM = Result HTML

 

For example, we have a list of User objects, which has name, address such properties.

We can display the users by following template

 

<!-- BEGIN DYNAMIC: users -->

Name: {name}

Address: {address}

<!-- END DYNAMIC: users -->

 

As we can see, XML Comment not affects HTML display effect in the Browser or HTML Editor like Dreamweaver.

 

For a if-else logic, like

<% if(name == null ){ %>

        No User Name Defined

<%}else if(isSuperUser(name)){%>

        Super User: <%= name %>

<%} else{%>

        Common User : <%= name %>

<%}%>

 

Fastm template should be:

 

<!-- BEGIN DYNAMIC: no_name -->

        No User Name Defined

<!-- END DYNAMIC: no_name -->

 

<!-- BEGIN DYNAMIC: super_user -->

        Super User: {name}

<!-- END DYNAMIC: super_user -->

 

<!-- BEGIN DYNAMIC: common_user -->

        Common User: {name}

<!-- END DYNAMIC: common_user -->

 

The logic is to be moved back to java code as:

 

Map map = new HashMap();

map.put(“name”, name);

If(name == null){
    map.put(“no_name”, map);

} else if(isSuperUser(name)){

    map.put(“super_user”, map);

}else{

    map.put(“common_user”, map);

}

 

Right. fastm template not supports script logic.

You have to write your logic in java code, like Jivan, XMLC, Wicket, etc.

 

As we can see, fastm is very easy and simple to use. And fastm has the fastest speed and smallest size among all template techs. 

 

9. The Good of Driving the Logic back to Java Code

(1) It solves the HTML code pollution. Template can be correctly displayed in the Browsers or HTML Editors.

(2) The logic in the Java code is easy to debug.

(3) The logic in the Java code is easy to reuse.

 

Here is the rationale of fastm:

Business logic is logic. Presentation logic is logic too.

Presentation logic should be organized neatly as Business logic too.

10. Designer friendly

fastm is quite “Designer friendly”.

fastm HTML template can be displayed correctly in the Browers or HTML editors. What you see is what you get”.

Microsoft provides XML formats of office documents.

For example, Excel (2002 or above) file can be saved and edited as XML format.

fastm works quite well for that too.

Fastm Excel XML template can be displayed correctly in the Excel too. “What you see is what you get”.

So in such kinds of “visual XML UI editors”, fastm has more advantages than scripts like JSP, Taglib, XSL, freemarker, velocity, Tapestry.

Wicket has the same “Designer friendly” effect as fastm too.

The most “Designer friendly” templates are Jivan, XMLC. They are just pure HTML, XML.

11. DOM Granularity, Reusability

Compared with XML DOM node, fastm Template DOM node is more flexible, since it is customized by user self.

For example, we want to display a list of users in two kinds of layout: list or table.

 

(1) XML DOM way

[code]

<ul>

<li> name: <span> show name here</span></li>

</ul>

 

<table>

<tr>

<td> name: <span> show name here</span></td>

</tr>

</table>

[/code]

 

As we can see, the 2 DOM level are different.

“List” has 3 levels; “Table” has 4 levels.

 

You may need to write 2 sets of “DOM manipulation” code for the 2 DOMs.

The DOM can not be shared. You modified the DOM, and then output it.

Next time, you need to operation on a fresh-new DOM.

 

(2) fastm way

[code]

<ul>

<!-- BEGIN DYNAMIC: user -->

<li> name: {name}</li>

<!-- END DYNAMIC: user -->

</ul>

 

<table>

<!-- BEGIN DYNAMIC: user -->

<tr>

<td> name: {user}</td>

</tr>

<!-- END DYNAMIC: user -->

</table>

[/code]

 

As we can see, both the “List” and “Table” templates have 2 levels.

We just need one set of code to get same Object DOM for the 2 Template DOMs.

Since the data is organized in the Object DOM, not directly put into the Template DOM, so the Template DOM can be shared. 

fastm Template DOM is read only and thread safe, which can be used any times by any number of concurrent programs.

12. Resource

The old version 1.0 alpha of fastm is on https://sourceforge.net/projects/fastm

The new version 1.0 M of fastm is on https://fastm.dev.java.net/

Please check the “Documents and Files”.

https://fastm.dev.java.net/servlets/ProjectDocumentList

That includes source, sample, doc of fastm1.0M, and view adapter for SpringMVC, WebWork.

https://fastm.dev.java.net/servlets/ProjectDocumentList?folderID=1552&expandFolder=1552&folderID=0

 

fastm

  • 2007年06月09日 17:02
  • 50KB
  • 下载

变革性的Java Web模板技术 -- fastm

变革性的Java Web模板技术 -- fastm 1.“简单就是美”空想(响)曲   在软件设计领域中,有一句脍炙人口的至理名言——简单即美好。 几乎所有的软件设计大师,都会在其著作中训导读...

fastm.jar

  • 2008年07月22日 10:22
  • 13KB
  • 下载

revolutionary.exe

  • 2014年03月19日 18:36
  • 1.17MB
  • 下载

Ray Ban Aviators the revolutionary chemical type

the newest chemical type A great year or so persists coming from May that will Sept. Unpredictabl...

SGU 525Revolutionary Roads (Tarjan+Dfs)

题意:

Linus Torvalds - Just for fun The Story of an Accidental Revolutionary

JUST FOR FUN 陈少芸译版《只是为了好玩 Linux之父林纳斯自传》 有些人生来就注定能领导几百万人,有些人生来就注定写出翻天覆地的软件。 但只有一个人两样都能做到:托瓦兹 一个...

revolutionary

  • 2011年08月09日 12:08
  • 1.5MB
  • 下载

中介者模式(Mediator) [非原创--该篇文章大部分内容来自Yan YAN's Tech Space,底部附 C++实现]

重要概念 中介者模式的结构        中介者模式又称为调停者模式,从类图中看,共分为3部分:  抽象中介者:定义好同事类对象到中介者对象的接口,用于各个同...
  • DOYEE
  • DOYEE
  • 2012年05月17日 17:09
  • 362
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Revolutionary Template Tech -- fastm
举报原因:
原因补充:

(最多只允许输入30个字)