我一直在尝试找出在 FuelPHP 中处理 i18n 的另一种方法(参见 here )。
我决定导入 Symfony2 Translation component (使用 Composer )作为供应商提供燃料并使用 xliff 文件管理 i18n。
这是我的(简化的)代码:
use \Symfony\Component\Translation\Translator;
use \Symfony\Component\Translation\MessageSelector;
use \Symfony\Component\Translation\Loader\XliffFileLoader;
...
class I18N
{
private static $translator = NULL;
....
public static function get($key)
{
# Load and configure the translator
self::$translator = new Translator('en_GB', new MessageSelector());
self::$translator->addLoader('xliff', new XliffFileLoader());
self::$translator->addResource('xliff', 'path/to/xliff/file', 'en');
# Get the translation
$translation = self::$translator->trans($key, $params);
# Return the translation
return $translation;
}
}
所以一开始我认为这工作得很好,因为我在一个非常小的 xliff 文件上测试它,但现在我已经为整个应用程序生成了完整的 xliff 目录(大约 1400 个条目),每个请求都非常慢。
所以问题是,在使用Translation component时有没有办法缓存翻译整个 Symfony2 框架以同样的方式本地缓存它?
Translator Class from the FrameworkBundle有一个接受选项的构造函数,您可以在其中定义cache_dir。无论如何,我可以使用 Translation component 来实现这一点?
感谢您就此事提供的任何帮助。
最佳答案
所以我所做的是从 xliff 文件生成我自己的缓存(如果它不存在),这只不过是作为 php 数组进行翻译,并使翻译器组件将资源加载为 ArrayLoader 而不是 XliffFileLoader。现在速度快如闪电。感谢 Touki 在评论中的关注。
关于从 Symfony2 翻译组件缓存目录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18615027/