flame / translator
Nette多语言应用程序的翻译器
dev-master
2017-03-08 03:27 UTC
Requires
- php: >=5.3.2
- nette/nette: >=2.0.1
Suggests
- flame/framework: >=2.0.0
This package is not auto-updated.
Last update: 2024-09-14 12:47:55 UTC
README
Nette Translator (c) Patrik Votoček (Vrtak-CZ), 2010 (http://patrik.votocek.cz)
注意
这是一份简短的指南,说明如何在最新版的Nette 2.0中以最简单的方式使用Nette Translator。无需编辑或操作.po/.mo文件。撰写于2012年2月10日。
实际信息/指南:http://wiki.nette.org/cs/cookbook/zprovozneni-prekladace-nettetranslator
1. 启用翻译器
config.neon
common:
services:
translator:
factory: \Flame\Translator\Gettext::getTranslator
setup:
- addFile(%appDir%/lang, front) # at leas one file required
- \Flame\Translator\Panel::register # panel to debug bar
注意:**请不要忘记使文件夹%appDir%/lang可写**
2. 在模板中使用
default.latte
{_"Dog"}
{_"Cat", $number} // for plural, default are Czech plurals: 1, 2-4, 5+
3. 在表单中使用
/** * Base presenter for all application presenters. */ abstract class BasePresenter extends Flame\Application\UI\Presenter { /** * @persistent */ public $lang; /** * @autowire * @var \Flame\Translator\Gettext */ protected $translator; /** * @autowire * @var \Nette\Http\Request */ protected $request; protected function startup() { parent::startup(); if (!$this->lang) { $lang = $this->request->detectLanguage(array('en', 'cs')) ?: 'cs'; $this->redirectUrl($lang); } } public function createTemplate($class = NULL) { $template = parent::createTemplate($class); $this->translator->setLang($this->lang); // set lang $template->setTranslator($this->translator); return $template; } }