Localization
Multilingual websites are widespread nowadays, which means that the
web-available texts have to be localized. Extbase provides the helper class
\TYPO3\ for the translation of the labels. Besides,
there is the Fluid ViewHelper <f:, with the help of whom you can use that
functionality in templates.
The localization class has only one public static method called translate, which
does all the translation. The method can be called like this:
use TYPO3\CMS\Extbase\Utility\LocalizationUtility;
$someString = LocalizationUtility::translate($key, $extensionName, $arguments);
$key- The identifier to be translated. If the format LLL:path:key is given, then this
identifier is used, and the parameter
$extensionis ignored. Otherwise, the fileName Resources/from the given extension is loaded, and the resulting text for the given key in the current language returned.Private/ Language/ locallang. xlf $extensionName - The extension name. It can be fetched from the request.
$arguments-
It allows you to specify an array of arguments. In the
Localization, these arguments will be passed to the functionUtility vsprintf. So you can insert dynamic values in every translation. You can find the possible wildcard specifiers under https://www.php.net/manual/function.sprintf.php#refsect1-function.sprintf-parameters.Example language file with inserted wildcards
EXT:my_extension/Resources/Private/Language/locallang.xlf<?xml version="1.0" encoding="UTF-8"?> <xliff version="1.0" xmlns="urn:oasis:names:tc:xliff:document:1.1"> <file source-language="en" datatype="plaintext" original="messages" date="..." product-name="..."> <header/> <body> <trans-unit id="count_posts"> <source>You have %d posts with %d comments written.</source> </trans-unit> <trans-unit id="greeting"> <source>Hello %s!</source> </trans-unit> </body> </file> </xliff>Copied!Called translations with arguments to fill data in wildcards
EXT:my_extension/Classes/Controller/SomeController.phpuse TYPO3\CMS\Extbase\Utility\LocalizationUtility; $someString = LocalizationUtility::translate('count_posts', 'BlogExample', [$countPosts, $countComments]) $anotherString = LocalizationUtility::translate('greeting', 'BlogExample', [$userName])Copied!