freemark ftl 的使用

WEB-INF目录下的freemark文件加载外部css、js、image文件解决方法

使用spring+freemark做项目的时候,经常碰到放在WEB-INF目录下的freemark文件加载外部css、js和image的时候失效,因为css、js和image路径不正确。

造成以上结果的原因有:

原因1(环境问题)、在web.xml文件中配置org.springframework.web.servlet.DispatcherServlet的时候url-pattern配置成了拦截所有(/*),或者配置成了包含有.css/.js/.jpg........等等后缀的拦截方式。

原因2(人为因素)、在ftl文件中导入css或者js或者image的时候,没有加上相对路径

              错误: yyy/xxx.css

              正确:${webApp的根}/ ${css/js/image文件存放目录}/yyy/xxx.css

 

解决方法:

假如有:如下配置

WEB-INF目录如下:在WEB-INF/template文件下有四个freemark文件,其中list.ftl用于列表显示数据

外部css、js及其image文件目录如下:

 

这时候,WEB-INF/template/list.ftl文件需要引入list.css文件样式,

首先要确保spring的拦截方式不包括css、js和image文件,这里配置成只拦截后缀是.sc的url请求

 

然后配置好freemark的全局变量

application-freemark.properties文件配置如下:

 

applicationContext-freemark.xml配置如下:


在WEB-INF/template/list.ftl文件引入list.css文件样式



css文件内容如下:

 

最终list.ftl的显示结果如下:


===================================================================================

同理,导入js文件

 



效果:

===========================================================================

加载图片的例子:


效果:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值