ファルコン-ビュー

ビューは、エンドユーザーに提示される情報です。ビューは、適切な応答が表示されるWebページと見なすことができます。応答は、モデルと相互作用するコントローラーを介して受信されます。

特にPhalconでは、ビューはVoltコード、PHP、およびHTMLで構成されています。ボルトモードに入るには、一連の特別な区切り文字を使用できます。{% ... %} forループや値の割り当てなどのステートメントを実行するために使用されます。 {{ ... }} 式の結果をテンプレートに出力します。

ファルコンのビューは基本的に2つのタイプに分類されます-

  • Volt
  • phtml

ボルト

以下は、プロジェクト用に作成した出力のスクリーンショットです。 demo1 前の章で。

この出力はファイルの助けを借りて達成されます views/index/index.volt

ボルトファイルの機能

  • これはC言語で書かれたテンプレートであり、他の言語と比較してかなり高速です。

  • これには、Phalconで非常に有益な高度に統合されたコンポーネントのセットが含まれています。

  • スタンドアロンコンポーネントとしても使用できます。

  • Voltは純粋なPHPコードにコンパイルされます。

以下はのコードです index.volt これは、すべてのプロジェクトに対してデフォルトでロードされます。

<!--<div class = "page-header"> 
   <h1>Congratulations!</h1> 
</div>--> 

<p>This is my first web application in Phalcon </p> 
<!--<p>You're now flying with Phalcon. Great things are about to happen!</p>

<p>This page is located at <code>views/index/index.volt</code></p>-->

階層レンダリング

Phalconのビューは、階層レンダリングと Phalcon\Mvc\Viewデフォルトのレンダリングコンポーネントとして使用されます。このコンポーネントは、テンプレート言語としてCを使用するvoltファイルと比較して、テンプレートエンジンとしてPHPを使用します。

これらのビューには .phtml拡張。特定のプロジェクトのデフォルトのビューディレクトリは、次の3つのファイルで構成されています-

  • Action view−このビューは、特定のアクションを実行するために呼び出されます。「show」アクションが実行されたときに呼び出されます。

  • Controller layout−このビューはlayoutsフォルダー内にあります。例えば、C:\xampp\htdocs\demo\app\views\layouts。適切なコントローラーに関連付けられたメソッド呼び出しを呼び出します。レイアウトに実装されたコードは、必要に応じて実装されます。

  • Main layout −このレイアウトビューはメインアクションを呼び出し、Webアプリケーション内のすべてのコントローラーまたはアクションに対して表示されます。

.voltファイルと.phtmlファイルの違い

。ボルト .phtml
.volt拡張子は、アプリケーションで設定されたテンプレートエンジンがCで記述されている場合に使用されます .phtmlは、テンプレートエンジンがPHP自体である場合に使用されます
スタンドアロンコンポーネントとして使用できます スタンドアロンコンポーネントとして使用することはできません
ボルトビューはPHPコードにコンパイルされます phtmlファイル自体にPHPコードが含まれているため、Phalconフレームワークでコンパイルする必要はありません。

変数

変数は、「set」を使用してテンプレートで割り当ておよび変更されます。

配列の宣言

{% set fruits = ['Apple', 'Banana', 'Orange'] %}

文字列の宣言

{% set name = ”John Kennedy” %}

コメント

コメントは、を使用してテンプレートに追加することもできます。 {# ... #}区切り文字。それらの中のすべてのテキストは、最終出力では無視されます。

{# note: this is a comment 
   {% set price = 100; %} 
#}

{% set fruits = ['Apple', 'Banana', 'Orange'] %} 

<h1>Fruits</h1> 

<ul> 
   {% for fruit in fruits %} 
   <li>{{ fruit|e }}</li> 
   {% endfor %} 
</ul>  

{% set robots = ['Voltron', 'Astro Boy', 'Terminator', 'C3PO'] %}  

<ul> 
   {% for robot in robots %} 
   <li>{{ robot }}</li> 
   {% endfor %} 
</ul>

出力

コードは次の出力画面を生成します-