Zend_Text_Table.xml 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15617 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.text.table.introduction">
  5. <title>Zend_Text_Table</title>
  6. <para>
  7. <classname>Zend_Text_Table</classname> ist eine Komponente für die Erstellung von
  8. Text-basierenden Tabellen welche mit unterschiedlichen Dekoratoren arbeitet. Das kann
  9. hilfreich sein, wenn man entweder strukturierte Daten in einer Textemail verwenden will,
  10. welche normalerweise mit monospaced Schriftarten geschrieben sind, oder um
  11. Tabelleninformationen in einer CLI Anwendung darzustellen.
  12. <classname>Zend_Text_Table</classname> unterstützt mehrzeilige Spalten, Colspan und auch
  13. Ausrichtung.
  14. </para>
  15. <note>
  16. <title>Kodierung</title>
  17. <para>
  18. <classname>Zend_Text_Table</classname> erwartet die Strings standardmäßig als UTF-8
  19. kodiert. Wenn das nicht der Fall ist, kann entweder die Zeichenkodierung als Parameter
  20. an den <code>Constructor</code> übergeben werden, oder an die <code>setContent</code>
  21. Methode von <classname>Zend_Text_Table_Column</classname>. Wenn man im kompletten
  22. Prozess eine andere Kodierung verwendet, kann man die standardmäßige Eingabekodierung
  23. mit <classname>Zend_Text_Table::setInputCharset($charset)</classname> setzen. Im Fall,
  24. das man eine andere Ausgabekodierung für die Tabelle benötigt, kann diese mit
  25. <classname>Zend_Text_Table::setOutputCharset($charset)</classname> gesetzt werden.
  26. </para>
  27. </note>
  28. <para>
  29. Ein <classname>Zend_Text_Table</classname> Objekt besteht aus Zeilen, die Spalten enthalten,
  30. repräsentiert durch <classname>Zend_Text_Table_Row</classname> und
  31. <classname>Zend_Text_Table_Column</classname>. Wenn eine Tabelle erstellt wird, kann ein
  32. Array mit Optionen für die Tabelle angegeben werden: Diese sind:
  33. <itemizedlist>
  34. <listitem>
  35. <para>
  36. <code>columnWidths</code> (required): Ein Array das alle Spalten mit Ihrer
  37. Breite in Zeichen definiert.
  38. </para>
  39. </listitem>
  40. <listitem>
  41. <para>
  42. <code>decorator</code>: Der Dekorator der für die Tabellenränder verwendet wird.
  43. Der Standard ist <code>unicode</code>, aber man kann auch <code>ascii</code>
  44. spezifizieren, oder eine Instanz eines eigenen Dekoratorobjekts angeben.
  45. </para>
  46. </listitem>
  47. <listitem>
  48. <para>
  49. <code>padding</code>: Die linke und rechte Füllung innerhalb der Spalten in
  50. Zeichen. Die Standardfüllung ist Null.
  51. </para>
  52. </listitem>
  53. <listitem>
  54. <para>
  55. <code>AutoSeparate</code>: Der Weg auf dem Zeilen mit horizontalen Linien
  56. getrennt werden. Der Standard ist eine Trennung zwischen allen Zeilen. Das ist
  57. als Bitmaske definiert die ein oder mehrere der folgenden Konstanten von
  58. <classname>Zend_Text_Table</classname> haben kann:
  59. <itemizedlist>
  60. <listitem>
  61. <para><classname>Zend_Text_Table::AUTO_SEPARATE_NONE</classname></para>
  62. </listitem>
  63. <listitem>
  64. <para>
  65. <classname>Zend_Text_Table::AUTO_SEPARATE_HEADER</classname>
  66. </para>
  67. </listitem>
  68. <listitem>
  69. <para>
  70. <classname>Zend_Text_Table::AUTO_SEPARATE_FOOTER</classname>
  71. </para>
  72. </listitem>
  73. <listitem>
  74. <para><classname>Zend_Text_Table::AUTO_SEPARATE_ALL</classname></para>
  75. </listitem>
  76. </itemizedlist>
  77. Wobei der Tabellenheader immer die erste Zeile, und der Tabellenfooter immer
  78. die letzte Zeile ist.
  79. </para>
  80. </listitem>
  81. </itemizedlist>
  82. </para>
  83. <para>
  84. Zeilen werden zur Tabelle einfach hinzugefügt indem eine neue Instanz von
  85. <classname>Zend_Text_Table_Row</classname> erstellt, und der Tabelle über die
  86. <code>appendRow</code> Methode angehängt wird. Zeilen selbst haben keine Optionen. Man kann
  87. der <code>appendRow</code> Methode auch direkt auch ein Array geben, welches dann
  88. automatisch in ein Zeilenobjekt konvertiert wird, welches mehrere Spaltenobjekte enthält.
  89. </para>
  90. <para>
  91. Auf dem gleichen Weg kann man Spalten zu Zeilen hinzufügen. Man erstellt eine neue Instanz
  92. von <classname>Zend_Text_Table_Column</classname> und setzt dann entweder die Zeilenoptionen
  93. im Constructor, oder später mit den <code>set*</code> Methoden. Der erste Parameter ist der
  94. Inhalt der Spalte, welcher mehrere Zeilen haben kann, welche im besten Fall einfach durch
  95. das <code>\n</code> Zeichen getrennt sind. Der zweite Parameter definiert die Ausrichtung,
  96. welche standardmäßig <code>left</code> ist, und eine der Klassenkonstanten von
  97. <classname>Zend_Text_Table_Column</classname> sein kann:
  98. <itemizedlist>
  99. <listitem>
  100. <para>
  101. <code>ALIGN_LEFT</code>
  102. </para>
  103. </listitem>
  104. <listitem>
  105. <para>
  106. <code>ALIGN_CENTER</code>
  107. </para>
  108. </listitem>
  109. <listitem>
  110. <para>
  111. <code>ALIGN_RIGHT</code>
  112. </para>
  113. </listitem>
  114. </itemizedlist>
  115. Der dritte Parameter ist die Colspan der Zeile. Wenn man, zum Beispiel, "2" als Colspan
  116. definiert, wird die Spalte über 2 Spalten der Tabelle gespannt. Der letzt Parameter
  117. definiert die Kodierung des Inhalts, welche angegeben werden sollte, wenn der Inhalt weder
  118. ASCII noch UTF-8 ist. Um die Spalte zur Zeile hinzuzufügen, muß einfach
  119. <code>appendColumn</code> im Zeilenobjekt, mit dem Spaltenobjekt als Parameter, aufgerufen
  120. werden. Alternativ kann ein String direkt an die <code>appendColumn</code> Methode übergeben
  121. werden.
  122. </para>
  123. <para>
  124. Um die Tabelle letztendlich darzustellen, kann man entweder die <code>render</code> Methode
  125. der Tabelle verwenden, oder die magische <code>__toString</code> Methode der Tabelle, indem
  126. man <code>echo $table;</code> oder <code>$tableString = (string) $table</code> ausführt.
  127. </para>
  128. <example id="zend.text.table.example.using">
  129. <title>Verwenden von Zend_Text_Table</title>
  130. <para>
  131. Ein Beispiel zeigt die grundsätzliche Verwendung von
  132. <classname>Zend_Text_Table</classname> um eine einfache Tabelle zu erstellen:
  133. </para>
  134. <programlisting language="php"><![CDATA[
  135. $table = new Zend_Text_Table(array('columnWidths' => array(10, 20)));
  136. // Entweder Einfach
  137. $table->appendRow(array('Zend', 'Framework'));
  138. // Oder wortreich
  139. $row = new Zend_Text_Table_Row();
  140. $row->appendColumn(new Zend_Text_Table_Column('Zend'));
  141. $row->appendColumn(new Zend_Text_Table_Column('Framework'));
  142. $table->appendRow($row);
  143. echo $table;
  144. ]]></programlisting>
  145. <para>
  146. Das führt zur folgenden Ausgabe:
  147. </para>
  148. <programlisting language="text"><![CDATA[
  149. ┌──────────┬────────────────────┐
  150. │Zend │Framework │
  151. └──────────┴────────────────────┘
  152. ]]></programlisting>
  153. </example>
  154. </sect1>
  155. <!--
  156. vim:se ts=4 sw=4 et:
  157. -->