同时使用Thymeleaf和JSP [英] Using both Thymeleaf and JSP
问题描述
我当时使用的是JSP + JSTL,但我对c:if,c:choose,...很无聊.
I was using JSP + JSTL but I'm boring of c:if, c:choose, ...
因此,我希望同时使用JSP和Thymeleaf呈现我的JSP页面(我计划尽快删除所有JSTL).我正在使用 Spring MVC 框架:
So, I want my JSP pages to be rendered with both JSP and Thymeleaf (I plan to remove all JSTL as soon as possible). I am using the Spring MVC framework:
<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/pages/" />
<property name="suffix" value=".jsp" />
<property name="order" value="1" />
</bean>
<!-- Thymeleaf -->
<bean id="templateResolver" class="org.thymeleaf.templateresolver.ServletContextTemplateResolver">
<property name="prefix" value="/WEB-INF/pages/" />
<property name="suffix" value=".html" />
<property name="templateMode" value="HTML5" />
</bean>
<bean id="templateEngine" class="org.thymeleaf.spring4.SpringTemplateEngine">
<property name="templateResolver" ref="templateResolver" />
</bean>
<bean class="org.thymeleaf.spring4.view.ThymeleafViewResolver">
<property name="templateEngine" ref="templateEngine" />
<property name="order" value="2" />
</bean>
在我的控制器中,我只返回了没有扩展的jsp.
In my controller, I just return the jsp without extenion.
return "folder/page";
可以先使用JSP解析器然后使用Thymeleaf解析器呈现我的JSP页面吗?如果是,怎么办?
似乎将JSP和Thymeleaf链接起来非常复杂.因此,我想将内部解析器用于JSP文件,将Thymeleaf模板解析器用于HTML文件.我该怎么办?
It seems that it is very complicated to chain JSP and Thymeleaf. So, I want to use the Internal resolver for JSP files and Thymeleaf template resolver for HTML files. How can I do it?
推荐答案
以下是基于@Igd响应的答案
Here is the answer based on @Igd response
<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/pages/" />
<property name="viewNames" value="*.jsp" />
</bean>
<!-- Thymeleaf -->
<bean id="templateResolver" class="org.thymeleaf.templateresolver.ServletContextTemplateResolver">
<property name="prefix" value="/WEB-INF/pages/" />
<property name="templateMode" value="HTML5" />
</bean>
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="viewNames" value="redirect*" />
</bean>
<bean id="templateEngine" class="org.thymeleaf.spring4.SpringTemplateEngine">
<property name="templateResolver" ref="templateResolver" />
</bean>
<bean class="org.thymeleaf.spring4.view.ThymeleafViewResolver">
<property name="templateEngine" ref="templateEngine" />
<property name="viewNames" value="*.html" />
</bean>
我将其用于映射:
@RequestMapping("/view1")
public String thymeleafView(){
return "mythymeleafview.html";
}
@RequestMapping("/view2")
public String jspView(){
return "myjspview.jsp";
}
这篇关于同时使用Thymeleaf和JSP的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!