翻译Symfony 6

rqcrx0a6  于 12个月前  发布在  其他
关注(0)|答案(1)|浏览(98)

总结:在多年没有使用symfony之后,我又回到了symfony(最后一个版本是symfony 2)。
我目前正试图处理一个最基本的问题是现在的框架:翻译。
但是无论我做什么,它似乎都不起作用(这意味着我看不到前端的翻译)。
这是你可能感兴趣的文件
config/packages/translation.yaml

framework:
    default_locale: en
    translator:
        default_path: '%kernel.project_dir%\translations'
        fallbacks:
            - en

translations/messages.fr.php

<?php

return [
    'Symfony is great' => "J'aime Symfony",
];

这部分似乎文件的原因,如果我提取翻译fr;翻译出现在出口日志。所以我的问题是如何使这个翻译有效。
这是我的主页(我只是用它来做语言选择和测试语言切换过程)

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Language Selector</title>
        <link rel="stylesheet" href="css/flag.css">
    </head>
    <body>
        <div class="language-selector-top">
            <h1>Configuration</h1>
            Current Locale is : {{ app.request.locale }}
            Try to translate following {{ "Symfony is great"|trans }}
        </div>
        <div class="language-selector">
            <div class="language-flag" data-lang="en_US">
                <img src="images/usa.jpg" alt="USA Flag">
                <div class="language-text">Configure my account in English !</div>
            </div>
            <div class="language-flag" data-lang="fr_FR">
                <img src="images/french.png" alt="French Flag">
                <div class="language-text">Configurer mon compte en Français !</div>
            </div>
            <div class="language-flag" data-lang="es_ES">
                <img src="images/mexican.png" alt="Mexican Flag">
                <div class="language-text">Configurar mi cuenta en Mexicano !</div>
            </div>
        </div>
        <script src="js/flag.js"></script>
    </body>
</html>

点击一个标志将触发一个ajax,这是应该改变语言

#[Route('/language/update')]
    public function updateLanguage(Request $request):JsonResponse
    {
        $previousLocale = $request->getLocale();
        $language = $request->get('language');

        // Update the Symfony locale based on the selected language
        //$this->localeSwitcher->setLocale($language);
        $request->setLocale($language);

        return new JsonResponse(
            [
                'oldLocale' => $previousLocale,
                'newLocale' => $language
            ]
        );
    }

结果,ajax返回以下控制台日志
{“oldLocale”:”zh“,“newLocale”:“fr_FR”}
问题是,当页面重新加载时,语言似乎一直是“en”,因为根本没有翻译。

flag.addEventListener('click', () => {
        const selectedLanguage = flag.getAttribute('data-lang');

        // Send an AJAX request to update the Symfony locale
        const xhr = new XMLHttpRequest();
        xhr.open('POST', '/language/update', true);
        xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
        xhr.onreadystatechange = function () {
            if (xhr.readyState === XMLHttpRequest.DONE) {
                if (xhr.status === 200) {
                    // Reload the page after successful language update
                    console.log(xhr.responseText);
                    window.location.href = '/';
                } else {
                    console.error('Failed to update language.');
                }
            }
        };
        xhr.send('language=' + encodeURIComponent(selectedLanguage));
    });

感谢您在此过程中的协助。

sxpgvts3

sxpgvts31#

在imo中,您必须将selected locale存储在会话中,然后使用侦听器(kernel.event_listener)从会话中为每个请求设置区域设置
注意:symfony本身有LocaleListener(优先级16 iirc),所以你的监听器必须有更高的优先级。
范例:

#[Route('/language/update')]
public function updateLanguage(Request $request):JsonResponse
{
    $previousLocale = $request->getLocale();
    $language = $request->get('language'); // should rename the param to locale
     
    $request->setLocale($language);

    $request->getSession()->set('locale', $language);

    return new JsonResponse([
        'oldLocale' => $previousLocale,
        'newLocale' => $language
    ]);
}
namespace App\Listener;

class LocaleListener
{
    public function onKernelRequest(RequestEvent $event): void
    {
        $request = $event->getRequest();
        // en_US: fallback to the default locale if it's not existed
        $request->setLocale($request->getSession()->get('locale', 'en_US'));
    }
}

在服务.yaml

App\Listener\LocaleListener:
    tags:
        - { name: kernel.event_listener, event: kernel.request, method: onKernelRequest, priority: 17 }

如果你不想自己处理语言环境的事情,有一个包可以解决https://github.com/lunetics-org/LocaleBundle

相关问题