让Nutz支持最快的模板引擎Smarty4j

Smarty4j是一个开源的模板引擎。没错,它就是著名的php模板引擎之Java移植版。 
它特点就是将模板文件或者字符串编译成java类直接执行,所以效率比一般的模板解释的方式处理要快。它发展较晚,所以没有 velocity、FreeMarker 有名,人气也比 php 版本的模板引擎差好多。 
但是它很快! 
本着怀疑一切的态度,我自己进行了实测。在渲染1000遍一个简单的页面时(只引入几种简单的数据类型), Smarty4j 耗时 16 毫秒,velocity 耗时 63 毫秒,FreeMarker 则用了 109 毫秒。渲染5000遍时,Smarty4j 耗时 172 毫秒,velocity 耗时 328 毫秒,FreeMarker 则用了 390 毫秒。(以上测试均为多次测试后取的平均值) 
复杂页面耗时相差更大。所以把项目里的 velocity 或 FreeMarker 换成 Smarty4j 可以使你的应用提速不少。

已经有网友将 Smarty4j 提供了插件集成到 struts2 中了。那么能不能把它集成到国产的小巧的 Nutz MVC 框架中呢? 
翻看了 Nutz 的用户手册后发现这是件非常容易的事情。

下面我们就开始吧:

1、首先要实现视图适配器 
非常简单:

Java代码  

  1. /**
  2. * Smarty4j 视图适配器
  3. * @author QinerG([email protected])
  4. */
  5. public class SmartyViewMaker implements ViewMaker {
  6. public View make(Ioc ioc, String type, String value) {
  7. if("st".equalsIgnoreCase(type)){
  8. return new SmartyView(value);
  9. }
  10. return null;
  11. }
  12. }

2、然后再实现具体的视图解析器

Java代码  

  1. /**
  2. * 使用 Smarty4j 模板生成页面
  3. * @author QinerG([email protected])
  4. */
  5. public class SmartyView extends AbstractPathView implements View {
  6. private final String ext = ".html";
  7. private static Engine engine = new Engine();//加载模板引擎
  8. public SmartyView(String dest) {
  9. super(dest);
  10. engine.setTemplatePath("");
  11. engine.setDebug(true);
  12. }
  13. /* 渲染页面
  14. * @see org.nutz.mvc.View#render(javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse, java.lang.Object)
  15. */
  16. public void render(HttpServletRequest req, HttpServletResponse resp,
  17. Object obj) throws Throwable {
  18. if ("".equals(engine.getTemplatePath())) {
  19. String realPath = req.getSession().getServletContext().getRealPath("/");
  20. engine.setTemplatePath(realPath);
  21. }
  22. String path = evalPath(req, obj);
  23. // 空路径,采用默认规则
  24. if (Strings.isBlank(path)) {
  25. path = Mvcs.getRequestPath(req);
  26. path = "WEB-INF"
  27. + (path.startsWith("/") ? "" : "/")
  28. + Files.renameSuffix(path, ext);
  29. }
  30. // 绝对路径 : 以 ‘/‘ 开头的路径不增加 ‘/WEB-INF‘
  31. else if (path.charAt(0) == ‘/‘) {
  32. if (!path.toLowerCase().endsWith(ext))
  33. path += ext;
  34. }
  35. // 包名形式的路径
  36. else {
  37. path = "WEB-INF/" + path.replace(‘.‘, ‘/‘) + ext;
  38. }
  39. Template template = engine.getTemplate(path);
  40. Context ctx = new Context(); // 生成数据容器对象
  41. ctx.set("obj", obj);
  42. ctx.set("request", req);
  43. ctx.set("response", resp);
  44. ctx.set("session", req.getSession());
  45. template.merge(ctx, resp.getWriter());
  46. }
  47. }

好了,完成!

那么具体怎么用呢? 
首先在主模块上声明使用 Smarty4j 适配器

Java代码  

  1. @Views({SmartyViewMaker.class})
  2. public class MainModule { }

然后在action上声明模板路径即可,如:

Java代码  

  1. @At("/index")
  2. @Ok("st:st.index")
  3. public void index() {

这个action的模板将对应 WEB-INF/st/index.html 文件。

当然模板路径也可以放在 WEB-INF 外面,如: 
@Ok("st:abc.bbc") 或 @Ok("st:/abc/bbc") 
对应的模板路径为: 
abc/bbc.html

时间: 2024-12-24 18:09:40

让Nutz支持最快的模板引擎Smarty4j的相关文章

.NET Core中使用Razor模板引擎

一.简介 在MVC以外的场景中,我们往往需要完成一些模板引擎生成代码或页面的工作:在以前我们一般常用的有Razor.NVeocity.VTemplate.虽然所有的模板系统都具有一些共同特征,但 Razor却和我们前面讨论的二种视图引擎截然不同.不同于其它视图引擎,Razor在使用XML代 码方面没有走得那么极端.它也不完全类似于ASPX,因为它把那些比较笨重的占位符替换成@符号接表达式或者普通的控制块.因为不需要特殊的结束标记,所 以Razor最终的代码很简练. 本篇介绍的主角是Razor,在

如何在express使用doT模板引擎

本文假设你已经使用过doT和express,并知道它的模板语法. js的模板引擎实在太多了,幸好 JavaScript template language shootoff 这篇不断被更新的文章,帮我们用真实的测试结果,得到了目前最快的模板引擎doT 安装dot $ sudo npm install dot 让express使用dot 安装express的模板引擎约定,引擎必须有一个compile方法,接受str和options参数,返回一个function对象即可,接口大致如下: export

改造Velocity模板引擎让$[!]{}输出默认进行html转义,并增加$#{}语法支持不转义输出

一直以来在项目中使用Apache Velocity模板引擎作为视图层输出,为了解决XSS漏洞,需要对输出到页面的内容进行HTML转义,我一般采用2种方式实现: 使用过滤器 Filter,在其中进行 HttpServletRequestWrapper 的 getParameter( )等方法重载,在底层进行HTML转义,然后页面直接输出: 这种方式很轻松很直接,业务代码不需要修改就完成了所有的转义工作:但是也带来了问题:修改了用户的原始输入数据,如果需要用到用户的原始输入数据,又得反转义回去,很麻

全球最快的JS模板引擎:tppl

废话不多说,先上测试: 亲测请访问:[在线测试地址]单次结果不一定准确,请多测几次. tppl 的编译渲染速度是著名的 jQuery 作者 John Resig 开发的 tmpl 的 43 倍!与第二名 artTemplate 也有一倍的差距. 似乎每一个大公司都选择自己开发模板引擎并将其开源,结果就是社区充斥着数不清的引擎,让人眼花缭乱无从选择.随着时间的流逝,越来越多的功能被添加进去,最终让一个强悍的发动机变成了一台臃肿复杂零件生锈的拖拉机.天呐,我就想网页面里插一段 html,你居然要我往

全球最快的JS模板引擎

废话不多说,先上测试: 亲测请访问:[在线测试地址]单次结果不一定准确,请多测几次. tppl 的编译渲染速度是著名的 jQuery 作者 John Resig 开发的 tmpl 的 43 倍!与第二名 artTemplate 也有一倍的差距. 似乎每一个大公司都选择自己开发模板引擎并将其开源,结果就是社区充斥着数不清的引擎,让人眼花缭乱无从选择.随着时间的流逝,越来越多的功能被添加进去,最终让一个强悍的发动机变成了一台臃肿复杂零件生锈的拖拉机.天呐,我就想网页面里插一段 html,你居然要我往

「快学springboot」SpringBoot整合freeMark模板引擎

前言 虽然现在流行前后端分离开发和部署,但是有时候还是需要用到服务端渲染页面的.比如:需要考虑到SEO优化等问题的时候,FreeMark其实还是很有作用的.本人的博客本来是用React开发的,但是后来发现搜索引擎难以收集由JS渲染的页面,所以前段时间,是用jQuery+FreeMark重写了我的博客前端页面.感兴趣的朋友,可以点击下面的查看更多的链接跳转至本人的博客. 在springboot中,不推荐使用JSP(其实任何项目都不推荐使用JSP),而是推荐使用模板引擎,如FreeMark.其实使用

《开源框架那点事儿25》:对框架模板引擎实现方式的改造实录

点滴悟透设计思想,Tiny模板引擎优化实录! 增加框架设计兴趣小组:http://bbs.tinygroup.org/group-113-1.html Tiny模板引擎的实现方式原来是採用的编译方式,近期发生了一些问题.因此我认为有必要把编译方式调整为解释方式,为此就開始了此次实现活动. 编译方式存在的问题 当时採用编译方式.主要是考虑到编译方式在执行时不必再去遍历语法树.因此就採用了编译方式. 可是在实际应用其中,出现了例如以下问题: 文件路径冲突的问题 因为採用的是编译方式,这个时候就存在在

JavaScript学习总结(一)——延迟对象、跨域、模板引擎、弹出层、AJAX示例

JavaScript学习总结(一)--延迟对象.跨域.模板引擎.弹出层.AJAX示例 目录 一.AJAX示例 1.1.优点 1.2.缺点 1.3.jQuery AJAX示例 二.延迟对象(Deferred) 2.1.回调函数 2.2.deferred.done 三.跨域 3.1.什么是跨域 3.2.JSONP跨域 3.3.jQuery使用JSONP跨域 3.4.跨域资源共享(CORS) 3.5.小结 四.弹出层 五.模板引擎 5.1.Hello World 5.2.方法 5.3.与AJAX结合应

js模板引擎介绍搜集

js模板引擎越来越多的得到应用,如今已经出现了几十种js模板引擎,国内各大互联网公司也都开发了自己的js模板引擎(淘宝的kissy template,腾讯的artTemplate,百度的baiduTemplate等),如何从这么多纷繁的模板引擎中选择一款适合自己的呢,笔者最近对主流的js模板引擎(mustache,doT,juicer,artTemplate,baiduTemplate,Handlebars,Underscore)做了一番调研,分享出来希望对大家有用. 从这几个指标来比较js模板