Zend_View-Helpers-HeadScript.xml 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190
  1. <!-- EN-Revision: 14463 -->
  2. <sect3 id="zend.view.helpers.initial.headscript">
  3. <title>L'aide de vue HeadScript</title>
  4. <para>L'élément HTML <code>&lt;script&gt;</code> est utilisé pour à la fois pour fournir des éléments de scripts
  5. côté-client dans le code HTML et aussi pour lier une ressource distante contenant du script côté-client. L'aide de
  6. vue <code>HeadScript</code> vous permet de gérer ces deux cas.</para>
  7. <para>L'aide de vue <code>HeadScript</code> supportent les méthodes suivantes pour paramétrer ou ajouter des scripts
  8. :</para>
  9. <itemizedlist>
  10. <listitem>
  11. <para><code>appendFile($src, $type = 'text/javascript', $attrs = array())</code></para>
  12. </listitem>
  13. <listitem>
  14. <para><code>offsetSetFile($index, $src, $type = 'text/javascript', $attrs = array())</code></para>
  15. </listitem>
  16. <listitem>
  17. <para><code>prependFile($src, $type = 'text/javascript', $attrs = array())</code></para>
  18. </listitem>
  19. <listitem>
  20. <para><code>setFile($src, $type = 'text/javascript', $attrs = array())</code></para>
  21. </listitem>
  22. <listitem>
  23. <para><code>appendScript($script, $type = 'text/javascript', $attrs = array())</code></para>
  24. </listitem>
  25. <listitem>
  26. <para><code>offsetSetScript($index, $script, $type = 'text/javascript', $attrs = array())</code></para>
  27. </listitem>
  28. <listitem>
  29. <para><code>prependScript($script, $type = 'text/javascript', $attrs = array())</code></para>
  30. </listitem>
  31. <listitem>
  32. <para><code>setScript($script, $type = 'text/javascript', $attrs = array())</code></para>
  33. </listitem>
  34. </itemizedlist>
  35. <para>Dans le cas des méthodes de type <code>*File()</code>, <code>$src</code> est l'emplacement distant du script à
  36. charger ; c'est généralement sous la forme d'une URL ou d'un chemin de fichier. Pour les méthode de type
  37. <code>*Script()</code>, <code>$script</code> sont les directives de script côté-client que vous souhaitez utiliser
  38. dans l'élément.</para>
  39. <note>
  40. <title>Paramétrez des commentaires conditionnels</title>
  41. <para><code>HeadScript</code> vous permet d'englober vos balises de script avec des commentaires conditionnels,
  42. ce qui permet de les masquer pour des navigateurs spécifiques. Pour ajouter les balises conditionnelles,
  43. fournissez le paramètre <code>conditional</code> en tant que partie du paramètre <code>$attrs</code> lors de
  44. l'appel de la méthode.</para>
  45. <example id="zend.view.helpers.initial.headscript.conditional">
  46. <title>Headscript avec des commentaires conditionnels</title>
  47. <programlisting role="php"><![CDATA[
  48. // adding scripts
  49. $this->headScript()->appendFile('/js/prototype.js',
  50. 'text/javascript',
  51. array('conditional' => 'lt IE 7');
  52. ]]></programlisting>
  53. </example>
  54. </note>
  55. <para><code>HeadScript</code> vous permet aussi de capturer des scripts ; ceci peut être utile si vous voulez créer
  56. du script côté-client par programmation, et ensuite le placer n'importe où. Une utilisation de ceci est montré dans
  57. un exemple ci-dessous.</para>
  58. <para>Enfin, vous pouvez aussi utiliser la méthode <code>headScript()</code> pour rapidement ajouter des éléments de
  59. script ; le prototype dans ce cas est <code>headScript($mode = 'FILE', $spec, $placement = 'APPEND')</code>. Le
  60. <code>$mode</code> est soit "FILE", soit "SCRIPT", suivant si vous liez un script ou que vous en définissiez un.
  61. <code>$spec</code> est soit le script à lier ou la source du script elle-même. <code>$placement</code> est "APPEND",
  62. "PREPEND", ou "SET".</para>
  63. <para><code>HeadScript</code> surcharge chacun des <code>append()</code>, <code>offsetSet()</code>,
  64. <code>prepend()</code>, et <code>set()</code> pour imposer l'utilisation des méthodes spéciales énumérées ci-dessus.
  65. En interne, il stocke chaque élément sous la forme d'un <code>stdClass</code>, qui peut être ensuite sérialisé grâce
  66. à la méthode <code>itemToString()</code>. Ceci vous permet de réaliser des vérifications sur les éléments dans la
  67. pile, et optionnellement de les modifier en modifiant simplement l'objet retourné.</para>
  68. <para>L'aide <code>HeadScript</code> est une implémentation concrète de l'<link
  69. linkend="zend.view.helpers.initial.placeholder">aide Conteneur</link>.</para>
  70. <note>
  71. <title>Utilisez InlineScript pour les scripts dans le corps ("body") du HTML</title>
  72. <para>L'aide de vue, <link linkend="zend.view.helpers.initial.inlinescript">InlineScript</link>, similaire à
  73. <code>HeadScript</code> devrait être utilisée quand vous souhaitez inclure des scripts dans le corps
  74. ("<classname>body</classname>") du HTML. Placer ces scripts en fin du document est une bonne pratique pour
  75. accélérer l'envoi de votre page, particulièrement pour les scripts tiers d'analyse.</para>
  76. </note>
  77. <note>
  78. <title>Les attributs arbitraires sont désactivées par défaut</title>
  79. <para>Par défaut, <code>HeadScript</code> affichera seulement les attributs de <code>&lt;script&gt;</code>
  80. approuvés par le W3C. Ceux-ci inclus "<code>type</code>", "<code>charset</code>", "<code>defer</code>",
  81. "<code>language</code>", et "<code>src</code>". Cependant, certaines bibliothèques javascript, notamment <ulink
  82. url="http://www.dojotoolkit.org/">Dojo</ulink>, utilise des attributs personnalisés dans le but de modifier le
  83. comportement. Pour autoriser ce type d'attribut, vous pouvez les activer grâce à la méthode
  84. <code>setAllowArbitraryAttributes()</code> :</para>
  85. <programlisting role="php"><![CDATA[
  86. $this->headScript()->setAllowArbitraryAttributes(true);
  87. ]]></programlisting>
  88. </note>
  89. <example id="zend.view.helpers.initial.headscript.basicusage">
  90. <title>Utilisation basique de l'aide HeadScript</title>
  91. <para>Vous devriez ajouter une nouvelle balise de script à chaque fois. Comme noté ci-dessus, ceux-ci peuvent
  92. être des liens vers des ressources externes ou vers les scripts eux-mêmes.</para>
  93. <programlisting role="php"><![CDATA[
  94. // ajout de scripts
  95. $this->headScript()->appendFile('/js/prototype.js')
  96. ->appendScript($onloadScript);
  97. ]]></programlisting>
  98. <para>L'ordre est souvent important avec les scripts côté-client ; vous devez vous assurer de charger les
  99. librairies dans un ordre spécifique en fonction de leurs dépendances ; utilisez à la fois les directives
  100. <code>append</code>, <code>prepend</code>, et <code>offsetSet</code> pour vous aider dans cette tâche :</para>
  101. <programlisting role="php"><![CDATA[
  102. // mettre les scripts dans l'ordre
  103. // placer celui-ci à un offset particulier pour s'assurer
  104. // de le charger en dernier
  105. $this->headScript()->offsetSetFile(100, '/js/myfuncs.js');
  106. // utiliser les effets de scriptaculous (append utilise
  107. // l'index suivant, c-à-d. 101)
  108. $this->headScript()->appendFile('/js/scriptaculous.js');
  109. // mais dans tous les cas, le script de base prototype
  110. // doit être chargé en premier :
  111. $this->headScript()->prependFile('/js/prototype.js');
  112. ]]></programlisting>
  113. <para>Quand vous êtes finalement prêt à afficher tous les scripts dans votre layout, faîtes simplement un
  114. <code>echo</code> de l'aide :</para>
  115. <programlisting role="php"><![CDATA[
  116. <?php echo $this->headScript() ?>
  117. ]]></programlisting>
  118. </example>
  119. <example id="zend.view.helpers.initial.headscript.capture">
  120. <title>Capturer les scripts en utilisant l'aide HeadScript</title>
  121. <para>Parfois vous devez générer des scripts côté-client par programme. Même si vous pouvez employer la
  122. concaténation de chaînes, les "heredocs", ou tout autre équivalent, il est souvent plus facile de faire juste la
  123. création des scripts et de les entourer par des balises PHP. <code>HeadScript</code> vous permet de le faire, et
  124. capture ainsi l'élément dans la pile :</para>
  125. <programlisting role="php"><![CDATA[
  126. <?php $this->headScript()->captureStart() ?>
  127. var action = '<?php echo $this->baseUrl ?>';
  128. $('foo_form').action = action;
  129. <?php $this->headScript()->captureEnd() ?>
  130. ]]></programlisting>
  131. <para>Les suppositions suivantes sont considérées :</para>
  132. <itemizedlist>
  133. <listitem>
  134. <para>Les déclarations de scripts sont ajoutées à la pile. Si vous souhaitez qu'elles remplacent la pile
  135. ou qu'elles soient ajoutées en début de pile, vous devez fournir "SET" ou "PREPEND", en tant que premier
  136. argument de <code>captureStart()</code>.</para>
  137. </listitem>
  138. <listitem>
  139. <para>Le type MIME est considéré comme étant "text/javascript" ; si vous souhaitez spécifier un type
  140. différent, vous devez le fournir en tant que deuxième argument de <code>captureStart()</code>.</para>
  141. </listitem>
  142. <listitem>
  143. <para>Si vous souhaitez spécifier un quelconque attribut additionnel pour la balise
  144. <code>&lt;script&gt;</code>, fournissez-le sous la forme d'un tableau en troisième argument de
  145. <code>captureStart()</code>.</para>
  146. </listitem>
  147. </itemizedlist>
  148. </example>
  149. </sect3>