slim 3 multilingual
1.1.3
تمديد الإصدار 3 النحيف PHP Micro-Framework لتمكين التوجيه القائم على اللغة ، أي I18N و L10N.
بواسطة Terminal:
composer require luism-s/multilingualslim يتم استخدام $container كواجهة بين البرامج الوسيطة والطرق. يقوم Multiliduage الوسيطة بحقن المتغيرات التالية في $container : default_language ، و available_languages and 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-Multilanguage ، والذي يتبع نفس الفلسفة ولكنه مصنوع للإصدار 2 من Slim.
تطوير وظائف للقيام بأشياء مثل اختبار اللغة الافتراضية ، والحصول على اللغة الحالية ، ومقارنة اللغة ، وربما أكثر.