Zend_View-Introduction.xml 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 15103 -->
  4. <sect1 id="zend.view.introduction">
  5. <title>導入</title>
  6. <para>
  7. <classname>Zend_View</classname> は、モデル - ビュー - コントローラ パターンにおける
  8. 「ビュー」として働くクラスです。
  9. ビューのスクリプトを、モデルおよびコントローラから分離するために存在します。
  10. このクラスでは、
  11. ヘルパーシステム、出力のフィルタリングおよび変数のエスケープ機能を提供します。
  12. </para>
  13. <para>
  14. <classname>Zend_View</classname> は、テンプレートシステムに対しては特にこだわりはありません。
  15. テンプレート言語として PHP を使用するか、
  16. あるいは他のテンプレートエンジンのインスタンスを作成して、
  17. それをビュースクリプトの中で操作することができます。
  18. </para>
  19. <para>
  20. 基本的に、<classname>Zend_View</classname> を使用する際には 2 つの段階をとることになります。
  21. 1. コントローラスクリプトが <classname>Zend_View</classname> のインスタンスを作成し、
  22. そのインスタンスに変数を代入します。
  23. 2. コントローラが <classname>Zend_View</classname> に対して適切なビューをレンダリングするように指示し、
  24. それによってコントローラがビュースクリプトを制御します。
  25. そこでビューの出力が作成されます。
  26. </para>
  27. <sect2 id="zend.view.introduction.controller">
  28. <title>コントローラスクリプト</title>
  29. <para>
  30. 単純な例として、本の一覧を扱うコントローラがあることにしましょう。
  31. そのデータをビューに表示することを考えます。
  32. コントローラスクリプトは、おそらくこのようになるでしょう。
  33. </para>
  34. <programlisting role="php"><![CDATA[
  35. // 本の著者およびタイトルを取得するためにモデルを使用します
  36. $data = array(
  37. array(
  38. 'author' => 'Hernando de Soto',
  39. 'title' => 'The Mystery of Capitalism'
  40. ),
  41. array(
  42. 'author' => 'Henry Hazlitt',
  43. 'title' => 'Economics in One Lesson'
  44. ),
  45. array(
  46. 'author' => 'Milton Friedman',
  47. 'title' => 'Free to Choose'
  48. )
  49. );
  50. // 本のデータを Zend_View インスタンスに代入します
  51. Zend_Loader::loadClass('Zend_View');
  52. $view = new Zend_View();
  53. $view->books = $data;
  54. // "booklist.php" というビュースクリプトをレンダリングします
  55. echo $view->render('booklist.php');
  56. ]]>
  57. </programlisting>
  58. </sect2>
  59. <sect2 id="zend.view.introduction.view">
  60. <title>ビュースクリプト</title>
  61. <para>
  62. 次に必要なのは、関連付けるビュースクリプト "booklist.php" です。
  63. これは一般的な PHP スクリプトと同じですが、ひとつだけ違いがあります。
  64. <classname>Zend_View</classname> インスタンスのスコープで実行されるということです。
  65. つまり $this への参照は、<classname>Zend_View</classname>
  66. のインスタンスのプロパティやメソッドを指すことになるのです
  67. (コントローラによってインスタンスに代入された変数は、
  68. <classname>Zend_View</classname> インスタンスの public プロパティとなります)。
  69. したがって、基本的なビュースクリプトはこのようになります。
  70. </para>
  71. <programlisting role="php"><![CDATA[
  72. if ($this->books): ?>
  73. <!-- 本の一覧 -->
  74. <table>
  75. <tr>
  76. <th>著者</th>
  77. <th>タイトル</th>
  78. </tr>
  79. <?php foreach ($this->books as $key => $val): ?>
  80. <tr>
  81. <td><?php echo $this->escape($val['author']) ?></td>
  82. <td><?php echo $this->escape($val['title']) ?></td>
  83. </tr>
  84. <?php endforeach; ?>
  85. </table>
  86. <?php else: ?>
  87. <p>表示する本がありません。</p>
  88. <?php endif;?>
  89. ]]>
  90. </programlisting>
  91. <para>
  92. 変数の出力時に、"escape()"
  93. メソッドでエスケープ処理をしていることに注意しましょう。
  94. </para>
  95. </sect2>
  96. <sect2 id="zend.view.introduction.options">
  97. <title>オプション</title>
  98. <para>
  99. <classname>Zend_View</classname> のオプションを設定すると、
  100. ビュースクリプトの振る舞いを変更することができます。
  101. </para>
  102. <itemizedlist>
  103. <listitem>
  104. <para>
  105. <code>basePath</code> は
  106. スクリプトやヘルパー、そしてフィルタを配置する基底パスを指定します。
  107. 次のようなディレクトリ構成を想定しています。
  108. </para>
  109. <programlisting role="php"><![CDATA[
  110. base/path/
  111. helpers/
  112. filters/
  113. scripts/
  114. ]]>
  115. </programlisting>
  116. <para>
  117. これを設定するには <code>setBasePath()</code> か
  118. <code>addBasePath()</code>、あるいはコンストラクタのオプション
  119. <code>basePath</code> を使用します。
  120. </para>
  121. </listitem>
  122. <listitem><para>
  123. <code>encoding</code> は <code>htmlentities()</code> や
  124. <code>htmlspecialchars()</code> などで使用する文字エンコーディングを表します。
  125. デフォルトは ISO-8859-1 (latin1) です。
  126. <code>setEncoding()</code> か、コンストラクタのオプション
  127. <code>encoding</code> で設定します。
  128. </para></listitem>
  129. <listitem><para>
  130. <code>escape</code> は <code>escape()</code>
  131. で使用するコールバックを表します。<code>setEscape()</code>
  132. か、コンストラクタのオプション <code>escape</code>
  133. で設定します。
  134. </para></listitem>
  135. <listitem><para>
  136. <code>filter</code> は、ビュースクリプトをレンダリングした後で使用するフィルタを表します。
  137. <code>setFilter()</code> か <code>addFilter()</code>、
  138. あるいはコンストラクタのオプション <code>filter</code>
  139. で設定します。
  140. </para></listitem>
  141. <listitem><para>
  142. <code>strictVars:</code> は、初期化していない変数に <classname>Zend_View</classname>
  143. からアクセスしようとした際に notice や warning を発生させるようにします。
  144. <code>strictVars(true)</code> か、あるいはコンストラクタのオプション
  145. <code>strictVars</code> で設定します。
  146. </para></listitem>
  147. </itemizedlist>
  148. </sect2>
  149. <sect2 id="zend.view.introduction.shortTags">
  150. <title>ビュースクリプトでの短いタグ</title>
  151. <para>
  152. 我々が用意する例やドキュメントでは、PHP の短いタグ
  153. <code>&lt;?</code> と <code>&lt;?=</code> を用いています。
  154. さらに、<ulink
  155. url="http://www.php.net/manual/ja/control-structures.alternative-syntax.php">
  156. 制御構造に関する別の構文</ulink>
  157. も使用しています。
  158. これらはビュースクリプトを書く際に便利なものです。
  159. より簡潔に書くことができ、文を 1 行にまとめられるからです。
  160. </para>
  161. <para>
  162. 多くの開発者は、可搬性などを考慮して完全なタグの使用を好むと言われています。
  163. 実際、php.ini.recommended ファイルでは
  164. <code>short_open_tag</code> が無効になっていますし、
  165. ビュースクリプト内で XML のテンプレートを使用する場合など、
  166. 短い形式の開始タグは検証エラーの元となります。
  167. </para>
  168. <para>
  169. さらに、もし短いタグが使用できない設定のときに短いタグを使用してしまうと、
  170. ビュースクリプトでエラーが発生したり
  171. コードの内容がユーザに丸見えになってしまったりします。
  172. </para>
  173. <para>
  174. 後者の場合のように「短いタグを使いたいけれど設定でそれが無効になっている」
  175. 場合は、次のいずれかの方法を使用します。
  176. </para>
  177. <itemizedlist>
  178. <listitem>
  179. <para>
  180. 短いタグを、<code>.htaccess</code> ファイルで有効にします。
  181. </para>
  182. <programlisting role="apache"><![CDATA[
  183. php_value "short_open_tag" "on"
  184. ]]>
  185. </programlisting>
  186. <para>
  187. これは、<code>.htaccess</code>
  188. ファイルの作成と使用を許可されている場合にのみ可能です。
  189. この項目は、<code>httpd.conf</code> ファイルに記述することもできます。
  190. </para>
  191. </listitem>
  192. <listitem>
  193. <para>
  194. オプションのストリームラッパーを有効にして、
  195. 短いタグを逐次長いタグに変換します。
  196. </para>
  197. <programlisting role="php"><![CDATA[
  198. $view->setUseStreamWrapper(true);
  199. ]]>
  200. </programlisting>
  201. <para>
  202. これは、<classname>Zend_View_Stream</classname>
  203. をビュースクリプトのストリームラッパーとして登録します。
  204. そして、まるで短いタグが有効になっているかのようにコードを動作させることができます。
  205. </para>
  206. </listitem>
  207. </itemizedlist>
  208. <note>
  209. <title>ビューストリームラッパーによるパフォーマンスの低下</title>
  210. <para>
  211. ストリームラッパーを使用すると、アプリケーションのパフォーマンスは
  212. <emphasis>おそらく</emphasis> 低下するでしょう。
  213. しかし、実際のところどれくらい低下するのかについては
  214. はっきりと数値化することはできません。
  215. 短いタグを有効にしてしまうか、
  216. スクリプトを書き換えてすべて完全なタグにしてしまう、
  217. あるいはコンテンツのキャッシュをうまく行うなどの対策を推奨します。
  218. </para>
  219. </note>
  220. </sect2>
  221. <sect2 id="zend.view.introduction.accessors">
  222. <title>ユーティリティメソッド</title>
  223. <para>
  224. 通常は、<code>assign()</code> と <code>render()</code>、
  225. あるいはフィルタ、ヘルパー、スクリプトのパス用の設定メソッドだけで十分事足りるでしょう。
  226. しかし、<classname>Zend_View</classname> を独自に拡張したい場合や
  227. その内部にアクセスしたい場合のために、さらにいくつかのメソッドを用意しています。
  228. </para>
  229. <itemizedlist>
  230. <listitem>
  231. <para>
  232. <code>getVars()</code> は、設定されているすべての変数を返します。
  233. </para>
  234. </listitem>
  235. <listitem>
  236. <para>
  237. <code>clearVars()</code> は、すべての変数の値を消去します。
  238. ビュースクリプトを再利用する際に、
  239. これまで使用していた変数を残しておきたいときなどに便利です。
  240. </para>
  241. </listitem>
  242. <listitem>
  243. <para>
  244. <code>getScriptPath($script)</code>
  245. は、指定したビュースクリプトのパスを取得します。
  246. </para>
  247. </listitem>
  248. <listitem>
  249. <para>
  250. <code>getScriptPaths()</code>
  251. は、登録されているすべてのスクリプトパスを取得します。
  252. script paths.
  253. </para>
  254. </listitem>
  255. <listitem>
  256. <para>
  257. <code>getHelperPath($helper)</code>
  258. は、指定したヘルパークラスのパスを取得します。
  259. </para>
  260. </listitem>
  261. <listitem>
  262. <para>
  263. <code>getHelperPaths()</code>
  264. は、登録されているすべてのヘルパーパスを取得します。
  265. </para>
  266. </listitem>
  267. <listitem>
  268. <para>
  269. <code>getFilterPath($filter)</code>
  270. は、指定したフィルタクラスのパスを取得します。
  271. </para>
  272. </listitem>
  273. <listitem>
  274. <para>
  275. <code>getFilterPaths()</code>
  276. は、登録されているすべてのフィルタパスを取得します。
  277. </para>
  278. </listitem>
  279. </itemizedlist>
  280. </sect2>
  281. </sect1>
  282. <!--
  283. vim:se ts=4 sw=4 et:
  284. -->