Перейти к основному содержимому

Руководство по усам с Spring Boot

· 3 мин. чтения

Упражнение: Сложение двух чисел

Даны два неотрицательный целых числа в виде непустых связных списков. Их цифры хранятся в обратном порядке. И каждый елемент списка содержить ровно одну цифру. Сложите эти два числа и верните сумму в виде связного списка ...

ANDROMEDA

1. Обзор

В этой статье мы сосредоточимся на использовании шаблонов Mustache для создания содержимого HTML в приложениях Spring Boot.

Это шаблонизатор без логики для создания динамического контента , который популярен благодаря своей простоте.

Если вы хотите узнать об основах, ознакомьтесь с нашей статьей « Введение в усы ».

2. Зависимость от Maven

Чтобы иметь возможность использовать Mustache вместе с Spring Boot, нам нужно добавить специальный стартер Spring Boot в наш pom.xml:

<dependency>            
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-mustache</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>

Кроме того, нам нужна зависимость spring-boot-starter-web .

3. Создание шаблонов

Давайте покажем пример и создадим простое приложение MVC с использованием Spring-Boot, которое будет обслуживать статьи на веб-странице.

Напишем первый шаблон для содержания статьи:

<div class="starter-template">
{{#articles}}
<h1>{{title}}</h1>
<h3>{{publishDate}}</h3>
<h3>{{author}}</h3>
<p>{{body}}</p>
{{/articles}}
</div>

Мы сохраним этот файл HTML, скажем, article.html, и сошлемся на него в нашем index.html:

<div class="container">
{{>layout/article}}
</div>

Здесь макет — это подкаталог, а статья — это имя файла для файла шаблона.

Обратите внимание, что расширение файла шаблона усов по умолчанию теперь . усы . Мы можем переопределить эту конфигурацию с помощью свойства:

spring.mustache.suffix:.html

4. Контроллер

Теперь напишем контроллер для отдачи статей:

@GetMapping("/article")
public ModelAndView displayArticle(Map<String, Object> model) {

List<Article> articles = IntStream.range(0, 10)
.mapToObj(i -> generateArticle("Article Title " + i))
.collect(Collectors.toList());

model.put("articles", articles);

return new ModelAndView("index", model);
}

Контроллер возвращает список статей для отображения на странице. В шаблоне статьи тег статьи , начинающийся с # и заканчивающийся на /, отвечает за список.

Это будет перебирать переданную модель и отображать каждый элемент отдельно, как в таблице HTML:

{{#articles}}...{{/articles}}

Метод generateArticle() создает экземпляр статьи с некоторыми случайными данными.

Обратите внимание, что ключи в модели статьи, возвращаемые контроллером, должны совпадать с ключами тегов шаблона статьи .

Теперь давайте протестируем наше приложение:

@Test
public void givenIndexPage_whenContainsArticle_thenTrue() {

ResponseEntity<String> entity
= this.restTemplate.getForEntity("/article", String.class);

assertTrue(entity.getStatusCode()
.equals(HttpStatus.OK));
assertTrue(entity.getBody()
.contains("Article Title 0"));
}

Мы также можем протестировать приложение, развернув его с помощью:

mvn spring-boot:run

После развертывания мы можем нажать localhost:8080/article, и мы получим список наших статей:

./b6d7d0599f60c71d45d531d6c56402a0.jpeg

5. Обработка значений по умолчанию

В среде Mustache, если мы не укажем значение для заполнителя, MustacheException будет выдано с сообщением «Нет метода или поля с именем «имя-переменной…».

Чтобы избежать таких ошибок, лучше указать глобальное значение по умолчанию для всех заполнителей:

@Bean
public Mustache.Compiler mustacheCompiler(
Mustache.TemplateLoader templateLoader,
Environment environment) {

MustacheEnvironmentCollector collector
= new MustacheEnvironmentCollector();
collector.setEnvironment(environment);

return Mustache.compiler()
.defaultValue("Some Default Value")
.withLoader(templateLoader)
.withCollector(collector);
}

6. Усы с Spring MVC

Теперь давайте обсудим, как интегрироваться со Spring MVC, если мы решим не использовать Spring Boot. Сначала добавим зависимость:

<dependency>
<groupId>com.github.sps.mustache</groupId>
<artifactId>mustache-spring-view</artifactId>
<version>1.4</version>
</dependency>

Последние можно было найти здесь .

Далее нам нужно настроить MustacheViewResolver вместо Spring InternalResourceViewResolver :

@Bean
public ViewResolver getViewResolver(ResourceLoader resourceLoader) {
MustacheViewResolver mustacheViewResolver
= new MustacheViewResolver();
mustacheViewResolver.setPrefix("/WEB-INF/views/");
mustacheViewResolver.setSuffix("..mustache");
mustacheViewResolver.setCache(false);
MustacheTemplateLoader mustacheTemplateLoader
= new MustacheTemplateLoader();
mustacheTemplateLoader.setResourceLoader(resourceLoader);
mustacheViewResolver.setTemplateLoader(mustacheTemplateLoader);
return mustacheViewResolver;
}

Нам просто нужно настроить суффикс, где хранятся наши шаблоны, префикс расширения наших шаблонов, и templateLoader, который будет отвечать за загрузку шаблонов.

7. Заключение

В этом кратком руководстве мы рассмотрели использование шаблонов Mustache с Spring Boot, рендеринг набора элементов в пользовательском интерфейсе, а также предоставление значений по умолчанию для переменных, чтобы избежать ошибок.

Наконец, мы обсудили, как интегрировать его со Spring, используя MustacheViewResolver.

Как всегда, исходный код доступен на GitHub .