Zend_Controller-ActionHelpers-Json.xml 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 16503 -->
  4. <sect3 id="zend.controller.actionhelpers.json">
  5. <title>JSON</title>
  6. <para>
  7. <acronym>JSON</acronym> レスポンスは、<acronym>AJAX</acronym> リクエストでデータセットを受け取るときの
  8. 形式としてすっかり定着しました。<acronym>JSON</acronym> はクライアント側で
  9. すぐにパースすることができ、すばやく実行できます。
  10. </para>
  11. <para>
  12. <acronym>JSON</acronym> アクションヘッダは次のようなことを行います。
  13. </para>
  14. <itemizedlist>
  15. <listitem><para>
  16. レイアウト機能が有効になっている場合はそれを無効にする。
  17. </para></listitem>
  18. <listitem>
  19. <para>
  20. 任意で、オプションの配列を
  21. <methodname>Zend_Json::encode()</methodname> の 2 番目の引数として渡す。
  22. このオプションの配列で、レイアウト機能を有効にしたり
  23. <classname>Zend_Json_Expr</classname> によるエンコードを有効にしたりする。
  24. </para>
  25. <programlisting language="php"><![CDATA[
  26. $this->_helper->json($data, array('enableJsonExprFinder' => true));
  27. ]]></programlisting>
  28. </listitem>
  29. <listitem><para>
  30. ViewRenderer が有効になっている場合にそれを無効にする。
  31. </para></listitem>
  32. <listitem><para>
  33. 'Content-Type' レスポンスヘッダを '<filename>application/json</filename>' に設定する。
  34. </para></listitem>
  35. <listitem><para>
  36. デフォルトでレスポンスをすぐに返す。
  37. アクションの実行が終了するのを待たない。
  38. </para></listitem>
  39. </itemizedlist>
  40. <para>
  41. 使い方は簡単です。ヘルパーブローカのメソッドとしてコールするか、
  42. <methodname>encodeJson()</methodname> あるいは
  43. <methodname>sendJson()</methodname> といったメソッドをコールするだけです。
  44. </para>
  45. <programlisting language="php"><![CDATA[
  46. class FooController extends Zend_Controller_Action
  47. {
  48. public function barAction()
  49. {
  50. // 何らかの処理をして...
  51. // JSON レスポンスを返します
  52. $this->_helper->json($data);
  53. // あるいは...
  54. $this->_helper->json->sendJson($data);
  55. // あるいは JSON を取得します
  56. $json = $this->_helper->json->encodeJson($data);
  57. }
  58. }
  59. ]]></programlisting>
  60. <note>
  61. <title>レイアウトの維持</title>
  62. <para>
  63. <acronym>JSON</acronym> レスポンスでレイアウト機能を使用したい場合
  64. (いくつかの <acronym>JSON</acronym> レスポンスをひとつにまとめて処理するなど)
  65. のために、<acronym>JSON</acronym> ヘルパーの各メソッドには
  66. 2 番目の引数が用意されています。
  67. この引数はオプションのフラグで、レイアウト機能を有効あるいは無効にします。
  68. <constant>TRUE</constant> を渡すと、レイアウト機能を有効なままにします。
  69. </para>
  70. <programlisting language="php"><![CDATA[
  71. $this->_helper->json($data, true);
  72. ]]></programlisting>
  73. <para>
  74. オプションで、2 番目の引数に配列を渡すことができます。
  75. この配列には、<emphasis>keepLayouts</emphasis>
  76. のオプションを含むさまざまなオプションを指定することができます。
  77. </para>
  78. <programlisting language="php"><![CDATA[
  79. $this->_helper->json($data, array('keepLayouts' => true);
  80. ]]></programlisting>
  81. </note>
  82. <note>
  83. <title>Zend_Json_Expr を使用したエンコードの有効化</title>
  84. <para>
  85. <methodname>Zend_Json::encode()</methodname> は、ネイティブ <acronym>JSON</acronym> 式を
  86. <classname>Zend_Json_Expr</classname> オブジェクトを使用してエンコードすることができます。
  87. このオプションはデフォルトでは無効になっています。
  88. 有効にするには、<emphasis>enableJsonExprFinder</emphasis>
  89. オプションに <constant>TRUE</constant> を設定します。
  90. </para>
  91. <programlisting language="php"><![CDATA[
  92. $this->_helper->json($data, array('enableJsonExprFinder' => true);
  93. ]]></programlisting>
  94. <para>
  95. これを行いたい場合は、2 番目の引数に必ず配列を渡さなければなりません。
  96. また、たとえば <emphasis>keepLayouts</emphasis> のような他のオプションと組み合わせることもできます。
  97. これらすべてのオプションが <methodname>Zend_Json::encode()</methodname> に渡されます。
  98. </para>
  99. <programlisting language="php"><![CDATA[
  100. $this->_helper->json($data, array(
  101. 'enableJsonExprFinder' => true,
  102. 'keepLayouts' => true,
  103. ));
  104. ]]></programlisting>
  105. </note>
  106. </sect3>
  107. <!--
  108. vim:se ts=4 sw=4 et:
  109. -->