我正在使用Thymeleaf为Spring Boot项目实现一个语言选择器,但是我无法在case语句中使用变量$ {#ctx.locale}。它始终是默认值(" *")。
<li class="nav-item dropdown">
<a class="nav dropdown-toggle"
id="languages" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
<i class="material-icons">language</i>
<div th:switch="${#ctx.locale}">
<p th:case="en">English</p>
<p th:case="es">Español</p>
<p th:case="ca">Català</p>
<p th:case="*">English</p>
</div>
</a>
<div class="dropdown-menu" aria-labelledby="languages">
<a class="dropdown-item" th:href="@{?lang=en}">English</a>
<a class="dropdown-item" th:href="@{?lang=es}">Español</a>
<a class="dropdown-item" th:href="@{?lang=ca}">Català</a>
</div>
事实上,我只需要语言名称。谢谢。
答案 0 :(得分:3)
解释如下:thymeleaf-compare-locale-expression-object-with-string
在您的代码更改th:switch="${#ctx.locale}" to th:switch="__${#locale.language}__"
<div th:switch="__${#locale.language}__">
<p th:case="en">English</p>
<p th:case="es">Español</p>
<p th:case="ca">Català</p>
<p th:case="*">English</p>
</div>