Phalcon-多言語サポート

ファルコンにはコンポーネントが含まれています Phalcon\Translate これは多言語サポートを提供し、複数の言語に翻訳されるWebページを作成するのに非常に役立ちます。

配列のバインドを支援し、翻訳メッセージの読み取りを支援するアダプターが含まれています。

PhalconのTranslateコンポーネントを使用して出力を作成しましょう。これは、提案された言語に従って出力を表示するのに役立ちます。

Step 1− Phalconは、すべての開発者に翻訳文字列を整理する自由を与えます。つまり、2つの異なるファイルを保持することを検討してください。en.php (英語の文字列の場合)および fr.php (フランス語の文字列の場合)。

ファイルには、キーと値のペアの配列が含まれます。キーは一意であり、必要な変換ごとに値が異なります。

en.php

<?php  

// app/messages/en.php 

$messagesContent = [ 
   "bye"     => "Good Bye", 
   "hi-name" => "Hello %name%", 
   "song"    => "Your favorite song is %song%", 
];

fr.php

<?php 

// app/messages/fr.php 

$messagesContent = [ 
   "bye"        => "Au revoir", 
   "hello-name" => "Bonjour %name%", 
   "song"       => "Votre chanson préférée est %song%", 
];

Step 2 −アプリケーションで、 UserController これは、翻訳に使用するファイルに関するパラメータを取ります。

<?php 

use Phalcon\Translate\Adapter\NativeArray; 

class UserController extends \Phalcon\Mvc\Controller {  
   protected function getMessageTransalation() { 
      // Ask for the best language 
      // Display the output in desired language 
      require "en.php";   
      
      // Return a translation object 
      return new NativeArray( ["content" => $messagesContent,]); 
   }  
   public function indexAction() { 
      $this->view->name = "Radhika"; 
      $this->view->song= "Ton sourire m'ensorcelle Je suis fou de toi Le désir coule dans mes veines Guidé par ta voix"; 
      $this->view->t    = $this->getMessageTransalation(); 
   } 
}

デフォルトの方法では、2つのパラメーターが使用されます。1つは名前、2つ目はユーザーのお気に入りの曲です。後で、機能getMessageTranslation が呼び出され、目的の出力が返されます。

今のところ、英語での出力が必要です。

Step 3 −関連する code view demo\app\views\User\index.volt 次のコードが含まれます-

<p><?php echo $t->_("hello-name", ["name" => $name]); ?></p> 
<p><?php echo $t->_("song", ["song" => $song]); ?></p>

完全な出力をフランス語で表示したい場合は、ファイル名を変更するだけで済みます。

require "fr.php";

以下はフランス語での出力です。