[笔记]《Spring实战》- 渲染Web视图

Posted symind

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了[笔记]《Spring实战》- 渲染Web视图相关的知识,希望对你有一定的参考价值。

一、理解解析

        Spring MVC定义了一个名为ViewResolver的接口,它大致如下所示:

public interface ViewResolver {
    View resolverViewName(String viewName, Locale locale) throws Exception;
}

        View是另外一个接口。

public interface View {
    String getContentType();
    void render(Map<String, ?> model, HttpServletRequest request, HttpServletResponse response) throws Exception;
}

        View接口的任务就是接受模型以及Servlet的request和response对象,并将输出结果渲染到response中。

        我们需要做的就是编写ViewResolver和View的实现,将要渲染的内容放到response中,进而展现到用户的浏览器中。实际上,Spring提供了多个内置的实现。

二、使用Thymeleaf

1. 配置Thymeleaf视图解析器

        为了要在Spring中使用Thymeleaf,我们需要配置三个启用Thymeleaf与Spring集成的bean:

  • ThymeleafViewResolver:将逻辑视图名称解析为Thymeleaf模板视图;
  • SpringTemplateEngine:处理模板并渲染结果;
  • TemplateResolver:加载Thymeleaf模板。

        如下为声明这些bean的Java配置。

        Thymeleaf3 之前的版本:

@Bean
public ViewResolver viewResolver(SpringTemplateEngine templateEngine) {
    ThymeleafViewResolver viewResolver = new ThymeleafViewResolver();
    viewResolver.setTemplateEngine(templateEngine);
    return viewResolver;
}

@Bean
public TemplateEngine templateEngine(TemplateResolver templateResolver) {
    SpringTemplateEngine templateEngine = new SpringTemplateEngine();
    templateEngine.setTemplateResolver(templateResolver);
    return templateEngine;
}

@Bean
public TemplateResolver templateResolver() {
    TemplateResolver templateResolver = new ServletContextTemplateResolver();
    templateResolver.setPrefix("/WEB-INF/templates/");
    templateResolver.setSuffix(".html");
    templateResolver.setTemplateMode("HTML5");
    return templateResolver;
}

 

       thymeleaf3 版本:

@Bean
public ViewResolver viewResolver(SpringTemplateEngine templateEngine) {
    ThymeleafViewResolver viewResolver = new ThymeleafViewResolver();
    viewResolver.setTemplateEngine(templateEngine);
    return viewResolver;
}

@Bean
public TemplateEngine templateEngine(TemplateResolver templateResolver) {
    SpringTemplateEngine templateEngine = new SpringTemplateEngine();
    templateEngine.setTemplateResolver(templateResolver);
    return templateEngine;
}

@Bean
public ITemplateResolver templateResolver() {
    TemplateResolver templateResolver = new SpringResourceTemplateResolver();
    templateResolver.setPrefix("/WEB-INF/templates/");
    templateResolver.setSuffix(".html");
    templateResolver.setTemplateMode("HTML5");
    return templateResolver;
}

 

        如果你更愿意使用XML来配置bean,那么如下的<bean>声明能够完成该任务。

<bean id="viewResolver"
    class="org.thymeleaf.spring3.view.ThymeleafViewResolver"
    p:templateEngine-ref="templateEngine" />

<bean id="templateEngine"
    class="org.thymeleaf.spring3.SpringTemplateEngine"
    p:templateResolver-ref="templateResolver" />

<bean id="templateResolver"
    class="org.thymeleaf.templateresolver.ServletContextTemplateResolver"
    p:prefix="/WEB-INF/templates"
    p:suffix=".html"
    p:templateMode="HTML5" />

2. 定义Thymeleaf模板

        Thymeleaf在很大程度上就是HTML文件,与JSP不同,它没有什么特殊的标签或标签库。Thymeleaf之所以能够发挥作用,是因为它通过自定义的命名控件,为标准的HTML标签集合添加Thymeleaf属性。

 

以上是关于[笔记]《Spring实战》- 渲染Web视图的主要内容,如果未能解决你的问题,请参考以下文章

Spring Boot? 使用freemarker模板引擎渲染web视图

Spring MVC:无法渲染视图 - $ 正在视图中渲染

Spring实战笔记:Web中的Spring

《spring实战》学习笔记-第五章:构建spring web应用程序

Spring Boot? 使用Thymeleaf模板引擎渲染web视图

Spring企业实战学习