设为首页 收藏本站
查看: 774|回复: 0

[经验分享] 使用Apache Tiles3.x构建界面布局(一)

[复制链接]
发表于 2018-11-22 06:35:21 | 显示全部楼层 |阅读模式
  Tiles是一个免费的开源模板Java应用程序的框架。基于复合模式简化的用户界面的构建。对于复杂的网站仍是最简单、最优雅的方式与任何MVC技术一起工作。Struts2对Tiles提供了支持,如今Tiles发展已有13个年头,成为Apache的一个独立项目,我们可以单独使用Tiles来构建用户界面布局。
  Tiles项目:http://tiles.apache.org/index.html
  Tiles的配置DTD定义:http://tiles.apache.org/framework/tiles-core/dtddoc/index.html
  

  本文主要通过构建一个简单的页面布局来认识Apache Tiles3.x(由于Tiles2.x和Tiles3.x存在较大差异)。

  

  1.准备工作
  1.1安装Apache Tiles3.x依赖的Jar

org.apache.tiles
tiles-extras
3.0.5


org.apache.tiles
tiles-servlet
3.0.5


org.apache.tiles
tiles-jsp
3.0.5
  注意:这里使用了Apache3.x完整包依赖。
  1.2调试环境
  安装jetty-maven-plugin来热部署web应用

tiles


org.mortbay.jetty
jetty-maven-plugin
7.1.6.v20100715

1
automatic

/tiles




  注意:运行mvn jetty:run -Djetty.port=9999 命名,访问http://localhost:9999/tiles 需要额外在Maven的settings.xml文件的插件组中添加插件组标识。

   
    org.mortbay.jetty
    

  1.3配置web.xml
  在web.xml中添加Tiles监听器

org.apache.tiles.extras.complete.CompleteAutoloadTilesListener
  关于Tiles的监听器可以自定义实现,参见:http://tiles.apache.org/framework/config-reference.html
  

  2.分析界面组成,构建布局文件

  假设本案例中的页面构成如图:

DSC0000.jpg

  分析界面布局,找不通用部分,特殊部分。 在webapp下创建layout文件夹放在布局文件,snippet文件夹放置公共部分。
  通过分析,将布局切割为header,body,footer,并且将HTML页面中的meta,script公共部分抽取出来。

  •   /snippet/meta.jsp



  •   /snippet/script.jsp


div {
width: 480px;
height: 80px;
background: silver;
}
#body {
background: lime;
}


document.writeln("这句话是由JavaScript写入页面的。");


  •   /snippet/header.jsp


这是头部


  •   /snippet/footer.jsp

这是页脚  


  •   /snippet/index_body.jsp



这是页面的主体部分
  

  通过上面的公共部分和主体,构建一个布局文件如下:
  


  •   /layout/index_layout.jsp





















  3.Tiles的复合布局定义
  Tiles是通过在xml文件中配置definition进行页面公共部分的重用,页面布局的组合。
  


  •   /WEB-INF/tiles-defs.xml 定义好公共部分之后,通过配置definition来组合页面布局。











  

  上面的definition可以说是抽象的,仅仅作为基本的定义抽取了界面中最通用的部分,而且并未指定具体的模版文件(布局文件)。下面通过继承tiles.base.definition来定一个tiles.index.definition其布局模版为/layout/index_layout.jsp。


  上面定义tiles.index.definition,新增了body,其值为/snippet/index_body.jsp页面。
  

  4.使用复合布局
  到这里已经将页面的布局进行了分割,组合。现在应用definition来构建一个请求响应页面。

  •   /example/index.jsp




  5.启动服务器,访问/example/index.jsp
  页面展示效果:
DSC0001.jpg

  接下来看看页面的源代码:





这是一个有Apache Tiles构建的页面布局.

div {
width: 480px;
height: 80px;
background: silver;
}
#body {
background: lime;
}


document.writeln("这句话是由JavaScript写入页面的。");





这是头部




这是页面的主体部分



这是页脚


  该例子中布局index_layout.jsp中body是可变的,title对一个不同的页面有不同的标题设置。在tiles-defx.xml的tiles.index.definition继承了tiles.base.definition,并且添加了其body页面,接着在插入tiles.index.definition的index.jsp页面添加了title。这样做达到的效果是整个站点的header,footer,meta,script抽取到了一个definition,然后通过继承的方式进行扩展,丰富不同的布局的页面组成元素,在具体的响应页面来定义专属该页面的内容。从而达到对页面的布局的控制,公共部分的复用的效果。
  

  6.总结
  本文仅仅是一个简单的示例,然而大部分内容被抽取公共部分占去,这样的结果并非意外,对于页面布局的划分,组合,重用才是使用Tiles之前最为繁重和复杂的工作,这些工作能够做的合理,优雅,配置definition自然就轻松多了。




运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-637909-1-1.html 上篇帖子: apache 的编译安装 下篇帖子: 使用Apache Tiles3.x构建界面布局(二)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表