本文主要是介绍用Grails的TagLib实现博客模板兼论TagLib是否应被一棍子打死,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
最近在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完全做不到这一点。
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:
- class YhTagLib{
- def booklist = { attrs, body ->
- def i = Integer.valueOf( attrs["times"] )
- def bs = Book.listOrderByName(max:i)
- for(b in bs){
- body(b)
- }
- }
- }
- <g:booklist times="10">
- <li>${it.name}li>
- g:booklist>
和开发一个JSP的TagLib相比,这是不是非常简单呢?也许有人说了,这有什么用呢?试想一下,如果我们做一个博客网站,把gsp作为用户可修改的模板,那用户就可以通过这些标签做出各种灵活多变的页面,换句话说,他们是在使用我们提供的标签编程。当然,在TagLib中直接操作数据也许会被认为是破坏了MVC结构,破坏了分层原则,但我认为在一些小型的应用中也无关紧要吧。
这篇关于用Grails的TagLib实现博客模板兼论TagLib是否应被一棍子打死的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!