欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

用Grails的TagLib实现博客模板兼论TagLib是否应被一棍子打死 GrailsColdFusionJSPAIRGroovy 

程序员文章站 2024-03-20 08:58:34
...
最近在JavaEye上参加了两次讨论,《Grails is a breath of fresh air for Java developers》和《Java web开发你还会选择其他的框架吗?》,在Robbin的带领下两次讨论渐渐变成了对TagLib的大批判,总体来说大概有两种观点,一种是以Robin为代表的革命派,认为TagLib是一种历史的倒退,早应该被抛弃了;另一种观点是TagLib确实很难看,不过也不是一无是处。

Robbin对TalLib是深恶痛绝的:

Grails只能使用JSP Tag作为view层实现,简直就是历史的倒退,基本上凡是强制使用JSP Tag的Java Web框架,我无一例外的反感……
只要JSF还用JSP Tag,就绝对不值得考虑……
jsp tag的致命缺点有三:
1、极难扩展

在页面扩展可重用片断,必须自己用Java编写自定义Tag。而这个工作对于模板语言例如freemarker来说是很简单的事情,即使可以自定义tag,也会造成tag泛滥,项目难以维护。

2、不能脱离Servlet容器存在
必须紧密藕合Servlet容器,造成View根本无法测试,无法扩展

3、无法动态切换View
对于类似博客网站是致命缺点,博客切换模板,要求根据程序的状态,动态切换整套不同的View,JSP Tag完全做不到这一点。

其实保这种观点的人还是很多的,今天看到ajax的站长李锟也这样说:

2001年我做Web开发使用的是ColdFusion,在当时几种Web开发技术ASP、PHP、JSP、ColdFusion中, ColdFusion的开发效率是最高的。但是ColdFusion是商业产品,在国内的用户很少。ColdFusion全部使用自定义的tag来做开 发,JSP开始支持自定义tag,并且在JSTL推出之后建议完全基于JSTL,而不是scriptlet做开发,这些在我看来就是对 ColdFusion的拙劣模仿。使用ColdFusion做开发的愉快感觉到了使用JSP就不存在了……

但是从上面这段话可以看出标签式的开发也不是一无是处的,李锟不也说在当时ColdFusion的开发效率是最高的吗?其实我认为TagLib虽然已被普遍抛弃,但有些场景还是可以做到事半功倍的,用一下也未尝不可,而且,Grails的TagLib开发起来是非常的简单的,下面我给出一个小例子。

在Grails的应用的taglib目录下新建一个文件YhTagLib.groovy:
java 代码
 
  1. class YhTagLib{  
  2.   
  3.     def booklist = { attrs, body ->  
  4.         def i = Integer.valueOf( attrs["times"] )  
  5.   
  6.         def bs = Book.listOrderByName(max:i)  
  7.   
  8.         for(b in bs){  
  9.             body(b)  
  10.         }  
  11.     }  
  12. }  
其中,Book是我已经建好的一个domain类,它有一个name属性,然后我们在gsp文件中就可以这样使用这个TagLib了:
xml 代码
 
  1. <g:booklist times="10">      
  2.       <li>${it.name}<!---->li>     
  3. <!---->g:booklist>    

和开发一个JSP的TagLib相比,这是不是非常简单呢?也许有人说了,这有什么用呢?试想一下,如果我们做一个博客网站,把gsp作为用户可修改的模板,那用户就可以通过这些标签做出各种灵活多变的页面,换句话说,他们是在使用我们提供的标签编程。当然,在TagLib中直接操作数据也许会被认为是破坏了MVC结构,破坏了分层原则,但我认为在一些小型的应用中也无关紧要吧。