slim 3 multilingual
1.1.3
スリムPHPマイクロフレームワークバージョン3の拡張は、言語ベースのルーティング、すなわちI18NおよびL10Nを有効にします。
ターミナルによる:
composer require luism-s/multilingualslim$container 、ミドルウェアとルートの間のインターフェイスとして使用されます。 MultilingUageミドルウェアは、次の変数を$containerに注入します: default_language 、 available_languagesおよびlanguage 。最初の2つは開発者によって設定された変数であり、最後はミドルウェア自体によって設定され、要求された言語を示します。
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
]);
});このプロジェクトは、同じ哲学に従っているが、Slimのバージョン2では行われているSimotod/Slim-Multilangageの主に影響を受けています。
デフォルト言語のテスト、現在の言語を取得し、言語を比較するなど、機能を実行する機能を開発します。