Attention
TYPO3 v11 has reached end-of-life as of October 31th 2024 and is no longer being maintained. Use the version switcher on the top left of this page to select documentation for a supported version of TYPO3.
Need more time before upgrading? You can purchase Extended Long Term Support (ELTS) for TYPO3 v11 here: TYPO3 ELTS.
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!