Zend_ProgressBar_Adapter_JsPush.xml 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 24249 -->
  3. <!-- Reviewed: no -->
  4. <sect3 id="zend.progressbar.adapter.jspush">
  5. <title>Zend_ProgressBar_Adapter_JsPush</title>
  6. <para>
  7. <classname>Zend_ProgressBar_Adapter_JsPush</classname> est un adaptateur qui vous
  8. permet de mettre à jour une barre de progression dans un navigateur au travers de
  9. Javascript. Ceci veut dire qu'une seconde connexion n'est pas nécessaire pour recueillir le
  10. statut du processus courant, mais que le processus lui-même envoie son statut directement au
  11. navigateur.
  12. </para>
  13. <para>
  14. Vous pouvez paramétrer les options de l'adaptateur soit avec les méthodes
  15. <code>set*</code> soit en fournissant un tableau ("array") ou une instance de
  16. <classname>Zend_Config</classname> contenant les options en tant que premier paramètre du
  17. constructeur. Les options disponibles sont :
  18. </para>
  19. <itemizedlist>
  20. <listitem>
  21. <para>
  22. <code>updateMethodName</code> : la méthode Javascript qui sera appelée à
  23. chaque mise à jour. La valeur par défaut est
  24. <classname>Zend_ProgressBar_Update</classname>.
  25. </para>
  26. </listitem>
  27. <listitem>
  28. <para>
  29. <code>finishMethodName</code> : la méthode Javascript qui sera appelée lorsque
  30. le statut terminé sera atteint. La valeur par défaut est <constant>NULL</constant>, qui veut
  31. dire que rien n'est fait.
  32. </para>
  33. </listitem>
  34. </itemizedlist>
  35. <para>
  36. L'utilisation de cet adaptateur est assez simple. Premièrement vous créez une barre de
  37. progression pour le navigateur, soit avec Javascript ou auparavant en pur HTML. Ensuite vous
  38. définissez une méthode de mise à jour et optionnellement une méthode de finalisation en
  39. Javascript, les deux acceptant un objet <acronym>JSON</acronym> en tant qu'unique argument. Ensuite vous
  40. appelez une page Web avec un processus chronophage dans une balise <code>iframe</code> ou
  41. <code>object</code> masqué. Pendant que le processus tourne, l'adaptateur appelle la méthode
  42. de mise à jour à chaque mise à jour avec un objet <acronym>JSON</acronym>, contenant le paramètres suivants
  43. :
  44. </para>
  45. <itemizedlist>
  46. <listitem>
  47. <para><code>current</code> : la valeur courante</para>
  48. </listitem>
  49. <listitem>
  50. <para><code>max</code> : la valeur maximum</para>
  51. </listitem>
  52. <listitem>
  53. <para><code>percent</code> : le pourcentage calculé</para>
  54. </listitem>
  55. <listitem>
  56. <para>
  57. <code>timeTaken</code> : le temps depuis quand le processus courant est en
  58. marche
  59. </para>
  60. </listitem>
  61. <listitem>
  62. <para>
  63. <code>timeRemaining</code> : le temps estimé pour que le processus se
  64. termine
  65. </para>
  66. </listitem>
  67. <listitem>
  68. <para><code>text</code> : le message de statut optionnel, si fourni</para>
  69. </listitem>
  70. </itemizedlist>
  71. <example id="zend.progressbar-adapter.jspush.example">
  72. <title>Exemple basique du fonctionnement côté-client</title>
  73. <para>
  74. Cet exemple illustre un paramétrage basique du HTML, <acronym>CSS</acronym> et JavaScript pour
  75. l'adaptateur JsPush :
  76. </para>
  77. <programlisting language="html"><![CDATA[
  78. <div id="zend-progressbar-container">
  79. <div id="zend-progressbar-done"></div>
  80. </div>
  81. <iframe src="long-running-process.php" id="long-running-process"></iframe>
  82. ]]></programlisting>
  83. <programlisting language="css"><![CDATA[
  84. #long-running-process {
  85. position: absolute;
  86. left: -100px;
  87. top: -100px;
  88. width: 1px;
  89. height: 1px;
  90. }
  91. #zend-progressbar-container {
  92. width: 100px;
  93. height: 30px;
  94. border: 1px solid #000000;
  95. background-color: #ffffff;
  96. }
  97. #zend-progressbar-done {
  98. width: 0;
  99. height: 30px;
  100. background-color: #000000;
  101. }
  102. ]]></programlisting>
  103. <programlisting language="javascript"><![CDATA[
  104. function Zend_ProgressBar_Update(data)
  105. {
  106. document.getElementById('zend-progressbar-done').style.width =
  107. data.percent + '%';
  108. }
  109. ]]></programlisting>
  110. <para>
  111. Ceci créera un simple conteneur avec une bordure noire et un bloc qui indique le
  112. niveau du processus courant. Vous ne devez pas masquer l'<code>iframe</code> ou
  113. l'<code>object</code> par <code>display: none;</code>, car dans ce cas les navigateurs
  114. comme Safari 2 ne chargeront pas le contenu réel.
  115. </para>
  116. <para>
  117. Plutôt que de créer votre barre de progression personnalisée, vous pouvez utiliser
  118. une de celles disponibles dans les librairies JavaScript comme Dojo, jQuery etc. Par
  119. exemple, il existe :
  120. </para>
  121. <itemizedlist>
  122. <listitem>
  123. <para>
  124. Dojo : <ulink
  125. url="http://dojotoolkit.org/reference-guide/dijit/ProgressBar.html"></ulink>
  126. </para>
  127. </listitem>
  128. <listitem>
  129. <para>
  130. jQuery : <ulink
  131. url="http://t.wits.sg/2008/06/20/jquery-progress-bar-11/"></ulink>
  132. </para>
  133. </listitem>
  134. <listitem>
  135. <para>
  136. MooTools : <ulink
  137. url="http://davidwalsh.name/dw-content/progress-bar.php"></ulink>
  138. </para>
  139. </listitem>
  140. <listitem>
  141. <para>
  142. Prototype : <ulink
  143. url="http://livepipe.net/control/progressbar"></ulink>
  144. </para>
  145. </listitem>
  146. </itemizedlist>
  147. </example>
  148. <note>
  149. <title>Intervalle de mise à jour</title>
  150. <para>
  151. Vous devez faire attention à ne pas envoyer trop de mises à jour, puisque chaque
  152. mise à jour a une taille minimum de 1ko. Ceci est requis par le navigateur Safari pour
  153. rendre et exécuter l'appel de fonction. Internet Explorer possède une limitation
  154. similaire mais à 256 octets.
  155. </para>
  156. </note>
  157. </sect3>