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的。
開發功能來執行諸如測試默認語言,獲取當前語言,比較語言以及更多內容之類的事情。