| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257 |
- <?xml version="1.0" encoding="UTF-8"?>
- <!-- Reviewed: no -->
- <!-- EN-Revision: 24997 -->
- <sect3 id="zend.view.helpers.initial.headscript">
- <title>HeadScript ヘルパー</title>
- <!-- Skip-EN-Revisions: 19437 -->
- <para>注意:このドキュメントでは、英語版のリビジョン 19437 の更新内容をスキップしています。</para>
- <para>
- <acronym>HTML</acronym> の <code><script></code> 要素を使用して、
- クライアントサイトのスクリプトをインラインで指定したり
- 外部のリソースからスクリプトのコードを読み込んだりします。
- <code>HeadScript</code> ヘルパーは、この両方の方式に対応しています。
- </para>
- <para>
- <code>HeadScript</code> ヘルパーは、
- 以下のメソッド群によってスクリプトの設定や追加をサポートします。
- </para>
- <itemizedlist>
- <listitem><para><code>appendFile($src, $type = 'text/javascript',
- $attrs = array())</code></para></listitem>
- <listitem><para><code>offsetSetFile($index, $src, $type = 'text/javascript',
- $attrs = array())</code></para></listitem>
- <listitem><para><code>prependFile($src, $type = 'text/javascript',
- $attrs = array())</code></para></listitem>
- <listitem><para><code>setFile($src, $type = 'text/javascript',
- $attrs = array())</code></para></listitem>
- <listitem><para><code>appendScript($script, $type = 'text/javascript',
- $attrs = array())</code></para></listitem>
- <listitem><para><code>offsetSetScript($index, $script, $type = 'text/javascript',
- $attrs = array())</code></para></listitem>
- <listitem><para><code>prependScript($script, $type = 'text/javascript',
- $attrs = array())</code></para></listitem>
- <listitem><para><code>setScript($script, $type = 'text/javascript',
- $attrs = array())</code></para></listitem>
- </itemizedlist>
- <para>
- <code>*File()</code> 系のメソッドでは、<varname>$src</varname>
- は読み込みたいリモートスクリプトの場所となります。
- 通常は、<acronym>URL</acronym> あるいはパスの形式となります。<code>*Script()</code>
- 系のメソッドでは、<varname>$script</varname>
- はその要素に使用したいクライアント側のスクリプトとなります。
- </para>
- <note>
- <title>条件コメントの設定</title>
- <para>
- <code>HeadScript</code> では、script タグを条件コメントで囲むことができます。
- そうすれば、特定のブラウザでだけスクリプトを実行しないこともできます。
- これを使用するには conditional タグを設定し、条件をメソッドコール時の
- <varname>$attrs</varname> パラメータで渡します。
- </para>
- <example id="zend.view.helpers.initial.headscript.conditional">
- <title>Headscript で条件コメントを使う例</title>
- <programlisting language="php"><![CDATA[
- // スクリプトを追加します
- $this->headScript()->appendFile(
- '/js/prototype.js',
- 'text/javascript',
- array('conditional' => 'lt IE 7')
- );
- ]]></programlisting>
- </example>
- </note>
- <!-- TODO : to be translated -->
- <note>
- <title>Preventing HTML style comments or CDATA wrapping of scripts</title>
- <para>
- By default <classname>HeadScript</classname> will wrap scripts with HTML
- comments or it wraps scripts with XHTML cdata. This behavior can be
- problematic when you intend to use the script tag in an alternative way by
- setting the type to something other then 'text/javascript'. To prevent such
- escaping, pass an <varname>noescape</varname> with a value of true as part of
- the <varname>$attrs</varname> parameter in the method calls.
- </para>
- <example id="zend.view.helpers.initial.headscript.noescape">
- <title>headScript で jQuery テンプレートを作成 </title>
- <programlisting language="php"><![CDATA[
- // jquery テンプレート
- $template = '<div class="book">{{:title}}</div>';
- $this->headScript()->appendScript(
- $template,
- 'text/x-jquery-tmpl',
- array('id='tmpl-book', 'noescape' => true)
- );
- ]]></programlisting>
- </example>
- </note>
- <para>
- <classname>HeadScript</classname> はスクリプトのキャプチャも行います。
- これは、クライアント側スクリプトをプログラム上で作成してから
- どこか別の場所で使いたい場合に便利です。
- 使用法は、以下の例で示します。
- </para>
- <para>
- <methodname>headScript()</methodname> メソッドを使うと、
- スクリプト要素を手っ取り早く追加できます。
- シグネチャは
- <methodname>headScript($mode = 'FILE', $spec, $placement = 'APPEND')</methodname>
- です。<varname>$mode</varname> は 'FILE' あるいは 'SCRIPT' のいずれかで、
- スクリプトへのリンクを指定するのかスクリプト自体を定義するのかによって切り替えます。
- <varname>$spec</varname> は、リンクするスクリプトファイルあるいはスクリプトのソースとなります。
- <varname>$placement</varname> は 'APPEND'、'PREPEND' あるいは 'SET'
- のいずれかでなければなりません。
- </para>
- <para>
- <code>HeadScript</code> は <methodname>append()</methodname> や
- <methodname>offsetSet()</methodname>、<methodname>prepend()</methodname>、そして <methodname>set()</methodname>
- をそれぞれオーバーライドして、上にあげた特別なメソッドを使用させるようにします。
- 内部的には、各項目を <code>stdClass</code> のトークンとして保管し、
- あとで <methodname>itemToString()</methodname> メソッドでシリアライズします。
- これはスタック内の項目についてチェックを行い、
- オプションでそれを修正したものを返します。
- </para>
- <para>
- <code>HeadScript</code> ヘルパーは、
- <link linkend="zend.view.helpers.initial.placeholder">Placeholder
- ヘルパー</link> の具象実装です。
- </para>
- <note>
- <title>HTML Body スクリプトでの InlineScript の使用</title>
- <para>
- <acronym>HTML</acronym> の <code>body</code> 部にスクリプトを埋め込みたい場合は、
- <code>HeadScript</code> の姉妹版である <link
- linkend="zend.view.helpers.initial.inlinescript">InlineScript</link>
- を使わなければなりません。
- スクリプトをドキュメントの最後のほうに配置するようにすると、
- ページの表示速度が向上します。特に、
- サードパーティのアクセス解析用スクリプトを使用する場合などにこの効果が顕著にあらわれます。
- </para>
- </note>
- <note>
- <title>すべての属性はデフォルトで無効</title>
- <para>
- デフォルトでは、<code>HeadScript</code> がレンダリングする
- <code><script></code> の属性は W3C
- に認められているものだけです。
- 'type' や 'charset'、'defer'、'language' そして 'src' が該当します。
- しかし、Javascript のフレームワーク
- (<ulink url="http://www.dojotoolkit.org/">Dojo</ulink> など)
- では独自の属性を用いることでその挙動を変更しています。
- このような属性を許可するには、
- <methodname>setAllowArbitraryAttributes()</methodname> メソッドを使用します。
- </para>
- <programlisting language="php"><![CDATA[
- $this->headScript()->setAllowArbitraryAttributes(true);
- ]]></programlisting>
- </note>
- <example id="zend.view.helpers.initial.headscript.basicusage">
- <title>HeadScript ヘルパーの基本的な使用法</title>
- <para>
- 上で説明したように、新しい script タグを、好きなときに指定できます。
- 外部のリソースへのリンクも可能ですし、
- スクリプト自体を指定することも可能です。
- </para>
- <programlisting language="php"><![CDATA[
- // スクリプトを追加します
- $this->headScript()->appendFile('/js/prototype.js')
- ->appendScript($onloadScript);
- ]]></programlisting>
- <para>
- クライアント側のスクリプトでは並び順が重要となります。
- 指定した並び順で出力させる必要が出てくることでしょう。
- そのために使用するのが、append、prepend そして offsetSet
- といったディレクティブです。
- </para>
- <programlisting language="php"><![CDATA[
- // スクリプトの順番を指定します
- // 特定の位置を指定し、確実に最後に読み込まれるようにします
- $this->headScript()->offsetSetFile(100, '/js/myfuncs.js');
- // scriptaculous のエフェクトを使用します (次のインデックスである 101 に追加されます)
- $this->headScript()->appendFile('/js/scriptaculous.js');
- // でも、もととなる prototype スクリプトは常に最初に読み込まれるようにします
- $this->headScript()->prependFile('/js/prototype.js');
- ]]></programlisting>
- <para>
- すべてのスクリプトを出力する準備が整ったら、
- あとはレイアウトスクリプトでそれを出力するだけです。
- </para>
- <programlisting language="php"><![CDATA[
- <?php echo $this->headScript() ?>
- ]]></programlisting>
- </example>
- <example id="zend.view.helpers.initial.headscript.capture">
- <title>HeadScript ヘルパーによるスクリプトのキャプチャ</title>
- <para>
- 時にはクライアント側のスクリプトをプログラムで生成しなければならないこともあるでしょう。
- 文字列の連結やヒアドキュメント等を使っても構いませんが、
- ふつうにスクリプトを作成してそれを <acronym>PHP</acronym> のタグに埋め込めればより簡単です。
- <code>HeadScript</code> は、スタックにキャプチャすることでこれを実現します。
- </para>
- <programlisting language="php"><![CDATA[
- <?php $this->headScript()->captureStart() ?>
- var action = '<?php echo $this->baseUrl ?>';
- $('foo_form').action = action;
- <?php $this->headScript()->captureEnd() ?>
- ]]></programlisting>
- <para>
- 前提条件は次のとおりです。
- </para>
- <itemizedlist>
- <listitem><para>
- スクリプトは、スタックの末尾に追加されていきます。
- 既存のスタックを上書きしたりスタックの先頭に追加したりしたい場合は、
- それぞれ 'SET' あるいは 'PREPEND' を
- <methodname>captureStart()</methodname> の最初の引数として渡します。
- </para></listitem>
- <listitem><para>
- スクリプトの <acronym>MIME</acronym> タイプは 'text/javascript' を想定しています。
- 別のものを指定したい場合は、それを
- <methodname>captureStart()</methodname> の 2 番目の引数として渡します。
- </para></listitem>
- <listitem><para>
- <code><script></code> タグに追加の属性を指定したい場合は、
- <methodname>captureStart()</methodname> の 3 番目の引数に配列形式で渡します。
- </para></listitem>
- </itemizedlist>
- </example>
- </sect3>
- <!--
- vim:se ts=4 sw=4 et:
- -->
|