Thymeleaf:语言选择器的switch语句

时间:2017-03-06 15:28:46

标签: spring-boot thymeleaf

我正在使用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>

事实上,我只需要语言名称。谢谢。

1 个答案:

答案 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>