slim 3 multilingual
1.1.3
扩展到Slim PHP Micro-Framework版本3,以启用基于语言的路由,即I18N和L10N。
由终端:
composer require luism-s/multilingualslim$container用作中间件和路由之间的接口。多语言中间件将以下变量注入$container : default_language , available_languages和language 。前两个是开发人员设置的变量,最后一个是由中间件本身设置的,并指示请求的语言。
use Psr Http Message ServerRequestInterface as Request ;
use Psr Http Message ResponseInterface as Response ;
require ' ../vendor/autoload.php ' ;
$ default_language = ' pt ' ;
$ available_languages = [ ' pt ' , ' en ' ];
$ app = new Slim App ();
$ container = $ app -> getContainer ();
$ app -> add ( new MultilingualSlim LanguageMiddleware ( $ available_languages , $ default_language , $ container ) );
$ app -> get ( ' / ' , function ( Request $ request , Response $ response ) {
// This works with '/', '/pt' and '/en',
// and prints 'Hello' in each language.
if ( $ this -> language === ' pt ' ) {
return $ response -> write ( " Olá Mundo " );
} elseif ( $ this -> language === ' en ' ) {
return $ response -> write ( " Hello World " );
}
});
$ app -> run ();您还可以使用库来渲染模板,例如PHP-View。例如:
$ container [ ' renderer ' ] = new Slim Views PhpRenderer ( " ../views/ " );
$ app -> get ( ' /home ' , function ( Request $ request , Response $ response ) {
// This works with '/home', '/pt/home' and '/en/home',
// and returns the template views/base.php.
// It also passes the chosen language as an argument accessible from the chosen template.
return $ this -> renderer -> render ( $ response , " base.php " , [
" language " => $ this -> language
]);
});该项目在很大程度上受Simotod/Slim-Multliningage的影响,该项目遵循相同的理念,但是针对Slim版本2的。
开发功能来执行诸如测试默认语言,获取当前语言,比较语言以及更多内容之类的事情。