Yii - Yerelleştirme
I18N (Internationalization)çeşitli dillere uyarlanabilen bir uygulama tasarlama sürecidir. Yii, eksiksiz bir I18N özellikleri yelpazesi sunar.
Yerel ayar, bir kullanıcının dilini ve ülkesini belirten bir dizi parametredir. Örneğin, en-US İngilizce yerel ayarı ve Amerika Birleşik Devletleri anlamına gelir. Yii iki tür dil sağlar: kaynak dil ve hedef dil. Kaynak dil, uygulamadaki tüm metin mesajlarının yazıldığı dildir. Hedef dil, içeriği son kullanıcılara göstermek için kullanılması gereken dildir.
Mesaj çeviri bileşeni, metin mesajlarını kaynak dilden hedef dile çevirir. Mesajı tercüme etmek için, mesaj çeviri servisinin mesajı bir mesaj kaynağında araması gerekir.
Mesaj çeviri hizmetini kullanmak için şunları yapmalısınız -
- Çevrilmesini istediğiniz metin mesajlarını Yii :: t () yöntemiyle sarın.
- Mesaj kaynaklarını yapılandırın.
- Mesajları mesaj kaynağında saklayın.
Step 1 - Yii :: t () yöntemi bu şekilde kullanılabilir.
echo \Yii::t('app', 'This is a message to translate!');
Yukarıdaki kod parçacığında, 'uygulama' bir mesaj kategorisi anlamına gelir.
Step 2 - Şimdi değiştirin config/web.php dosya.
<?php
$params = require(__DIR__ . '/params.php'); $config = [
'id' => 'basic',
'basePath' => dirname(__DIR__),
'bootstrap' => ['log'],
'components' => [
'request' => [
// !!! insert a secret key in the following (if it is empty) - this
//is required by cookie validation
'cookieValidationKey' => 'ymoaYrebZHa8gURuolioHGlK8fLXCKjO',
],
'cache' => [
'class' => 'yii\caching\FileCache',
],
'i18n' => [
'translations' => [
'app*' => [
'class' => 'yii\i18n\PhpMessageSource',
'fileMap' => [
'app' => 'app.php'
],
],
],
],
'user' => [
'identityClass' => 'app\models\User',
'enableAutoLogin' => true,
],
'errorHandler' => [
'errorAction' => 'site/error',
],
'mailer' => [
'class' => 'yii\swiftmailer\Mailer',
// send all mails to a file by default. You have to set
// 'useFileTransport' to false and configure a transport
// for the mailer to send real emails.
'useFileTransport' => true,
],
'log' => [
'flushInterval' => 1,
'traceLevel' => YII_DEBUG ? 3 : 0,
'targets' => [
[
'class' => 'yii\log\FileTarget',
'exportInterval' => 1,
'logVars' => [],
],
],
],
'db' => require(__DIR__ . '/db.php'),
],
// set target language to be Russian
'language' => 'ru-RU',
// set source language to be English
'sourceLanguage' => 'en-US',
'modules' => [
'hello' => [
'class' => 'app\modules\hello\Hello',
],
],
'params' => $params, ]; if (YII_ENV_DEV) { // configuration adjustments for 'dev' environment $config['bootstrap'][] = 'debug';
$config['modules']['debug'] = [ 'class' => 'yii\debug\Module', ]; $config['bootstrap'][] = 'gii';
$config['modules']['gii'] = [ 'class' => 'yii\gii\Module', ]; } return $config;
?>
Yukarıdaki kodda kaynak ve hedef dilleri tanımlıyoruz. Ayrıca aşağıdakiler tarafından desteklenen bir mesaj kaynağı da belirtiyoruz:yii\i18n\PhpMessageSource. Uygulama * kalıbı, uygulama ile başlayan tüm mesaj kategorilerinin bu belirli mesaj kaynağı kullanılarak çevrilmesi gerektiğini belirtir. Yukarıdaki yapılandırmada, tüm Rusça çeviriler messages / ru-RU / app.php dosyasında yer alacaktır.
Step 3- Şimdi, messages / ru-RU dizin yapısını oluşturun. Ru-RU klasörünün içinde app.php adlı bir dosya oluşturun. Bu, tüm EN → RU çevirilerini saklayacaktır.
<?php
return [
'This is a string to translate!' => 'Эта строка для перевода!'
];
?>
Step 4 - SiteController'da actionTranslation () adlı bir işlev oluşturun.
public function actionTranslation() {
echo \Yii::t('app', 'This is a string to translate!');
}
Step 5 - URL'yi girin http://localhost:8080/index.php?r=site/translation web tarayıcısında aşağıdakileri göreceksiniz.
Hedef dili ru-RU olarak belirlediğimiz için mesaj Rusçaya çevrildi. Uygulamanın dilini dinamik olarak değiştirebiliriz.
Step 6 - Değiştirin actionTranslation() yöntem.
public function actionTranslation() {
\Yii::$app->language = 'en-US';
echo \Yii::t('app', 'This is a string to translate!');
}
Şimdi, mesaj İngilizce olarak görüntüleniyor -
Step 7 - Çevrilmiş bir mesaja bir veya daha fazla parametre ekleyebilirsiniz.
public function actionTranslation() {
$username = 'Vladimir';
// display a translated message with username being "Vladimir"
echo \Yii::t('app', 'Hello, {username}!', [
'username' => $username, ]), "<br>"; $username = 'John';
// display a translated message with username being "John"
echo \Yii::t('app', 'Hello, {username}!', [
'username' => $username, ]), "<br>"; $price = 150;
$count = 3; $subtotal = 450;
echo \Yii::t('app', 'Price: {0}, Count: {1}, Subtotal: {2}', [$price, $count, $subtotal]);
}
Aşağıdakiler çıktı olacaktır.
Tek tek metin mesajlarını çevirmek yerine tüm görünüm komut dosyasını çevirebilirsiniz. Örneğin, hedef dil ru-RU ise ve views / site / index.php görünüm dosyasını çevirmek istiyorsanız, görünümü çevirmeli ve views / site / ru-RU dizini altına kaydetmelisiniz.
Step 8- views / site / ru-RU dizin yapısını oluşturun. Ardından, ru-RU klasörünün içinde aşağıdaki kodla index.php adında bir dosya oluşturun.
<?php
/* @var $this yii\web\View */
$this->title = 'My Yii Application';
?>
<div class = "site-index">
<div class = "jumbotron">
<h1>Добро пожаловать!</h1>
</div>
</div>
Step 9 - Hedef dil ru-RU'dur, bu nedenle URL'yi girerseniz http://localhost:8080/index.php?r=site/index, Rusça tercümeli sayfayı göreceksiniz.